.news-page { max-width: 920px; margin: 0 auto; padding: 48px 24px 80px; }

/* ── Liste ── */
.news-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; }
.nc-card {
  display: flex; flex-direction: column;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 12px; overflow: hidden; cursor: pointer;
  text-decoration: none; transition: border-color .2s, transform .18s;
}
.nc-card:hover { border-color: rgba(100,160,220,.28); transform: translateY(-3px); }
.nc-card-img { width: 100%; aspect-ratio: 16/8; object-fit: cover; background: rgba(58,139,186,.1); display: block; }
.nc-card-body { padding: 16px 18px 18px; flex: 1; display: flex; flex-direction: column; }
.nc-meta { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.nc-tag { font-size: .6rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; background: rgba(58,139,186,.15); color: #5aadd4; border: 1px solid rgba(58,139,186,.28); padding: 2px 8px; border-radius: 20px; }
.nc-date { font-size: .68rem; color: rgba(160,180,220,.45); }
.nc-title { font-family: 'Cinzel', serif; font-size: 1rem; font-weight: 700; color: #dce8f8; line-height: 1.35; margin-bottom: 8px; }
.nc-excerpt { font-size: .8rem; color: rgba(180,200,235,.65); line-height: 1.65; flex: 1; }

/* ── Détail ── */
.nd-back { display: inline-flex; align-items: center; gap: 6px; font-size: .75rem; color: #5aadd4; cursor: pointer; margin-bottom: 28px; text-decoration: none; opacity: .8; transition: opacity .15s; background: none; border: none; padding: 0; }
.nd-back:hover { opacity: 1; }

.nd-meta { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.nd-tag { font-size: .62rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; background: rgba(58,139,186,.18); color: #5aadd4; border: 1px solid rgba(58,139,186,.3); padding: 2px 10px; border-radius: 20px; }
.nd-date { font-size: .72rem; color: rgba(160,180,220,.5); }
.nd-title { font-family: 'Cinzel', serif; font-size: 1.55rem; font-weight: 700; color: #dce8f8; line-height: 1.28; margin-bottom: 24px; letter-spacing: .02em; }
.nd-body { color: rgba(200,215,240,.82); font-size: .95rem; line-height: 1.85; }
.nd-body p { margin: 0 0 16px; }
.nd-body strong { color: #d4dff5; }
.nd-body em { color: rgba(200,215,240,.7); font-style: italic; }

.nd-facts { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px; margin: 24px 0; }
.nd-fact { background: rgba(58,139,186,.08); border: 1px solid rgba(58,139,186,.18); border-radius: 8px; padding: 13px 15px; }
.nd-fact-lbl { font-size: .6rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: #5aadd4; margin-bottom: 4px; }
.nd-fact-val { font-family: 'Cinzel', serif; font-size: .86rem; font-weight: 600; color: #dce8f8; }

.nd-cta-row { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 24px; margin-bottom: 40px; }
.nd-cta { display: inline-flex; align-items: center; gap: 7px; background: linear-gradient(135deg,rgba(58,139,186,.25),rgba(58,139,186,.12)); border: 1px solid rgba(58,139,186,.4); color: #5aadd4; border-radius: 8px; padding: 10px 20px; font-size: .82rem; font-weight: 600; text-decoration: none; transition: background .2s, border-color .2s; }
.nd-cta:hover { background: rgba(58,139,186,.35); border-color: rgba(58,139,186,.7); color: #8dcfef; }

.nd-disclaimer { margin-top: 0; padding: 13px 17px; background: rgba(255,255,255,.03); border-left: 2px solid rgba(160,180,220,.15); border-radius: 0 6px 6px 0; font-size: .74rem; color: rgba(160,180,220,.4); line-height: 1.6; }
.nd-disclaimer a { color: inherit; opacity: .7; }

/* Image cover skeleton + fade-in */
.nd-img-wrap { width: 100%; aspect-ratio: 16/7; border-radius: 10px; margin-bottom: 28px; overflow: hidden; background: linear-gradient(90deg,rgba(255,255,255,.04) 25%,rgba(255,255,255,.09) 50%,rgba(255,255,255,.04) 75%); background-size: 200% 100%; animation: nd-sk 1.4s infinite; }
.nd-img-wrap.loaded { animation: none; background: none; }
.nd-img { width: 100%; height: 100%; object-fit: cover; display: block; opacity: 0; transition: opacity .55s ease; }
.nd-img-wrap.loaded .nd-img { opacity: 1; }

/* ── États vide / chargement ── */
.news-empty { text-align: center; padding: 60px 20px; color: rgba(160,180,220,.4); }
.news-empty svg { margin-bottom: 16px; opacity: .3; }
.news-empty p { font-size: .9rem; line-height: 1.7; }
.news-loading { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; }
.nc-skel { border-radius: 12px; overflow: hidden; background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.06); }
.nc-skel-img { width: 100%; aspect-ratio: 16/8; background: linear-gradient(90deg,rgba(255,255,255,.04) 25%,rgba(255,255,255,.09) 50%,rgba(255,255,255,.04) 75%); background-size:200% 100%; animation: nd-sk 1.4s infinite; }
.nc-skel-body { padding: 14px 16px 18px; }
.nc-skel-line { height: 10px; border-radius: 5px; margin-bottom: 8px; background: linear-gradient(90deg,rgba(255,255,255,.04) 25%,rgba(255,255,255,.09) 50%,rgba(255,255,255,.04) 75%); background-size:200% 100%; animation: nd-sk 1.4s infinite; }
.nc-skel-line.wide { width: 80%; }
.nc-skel-line.med  { width: 55%; }
@keyframes nd-sk { 0% { background-position:200% 0; } 100% { background-position:-200% 0; } }
