/* =====================================================
   Article Titles Display — Frontend CSS
   ===================================================== */

.atd-wrapper { list-style: none; margin: 0; padding: 0; }
.atd-item    { box-sizing: border-box; }

/* Thumbnail */
.atd-thumbnail     { margin-bottom: 10px; }
.atd-thumbnail img { max-width: 100%; height: auto; display: block; border-radius: 4px; }

/* Titre */
.atd-title { margin: 0; }
.atd-title a { text-decoration: none; transition: color .2s; }

/* Méta */
.atd-meta { display: flex; flex-wrap: wrap; gap: 8px; font-size: .82em; margin-top: 4px; }
.atd-meta span::before { content: '·'; margin-right: 6px; opacity: .5; }
.atd-meta span:first-child::before { content: ''; margin: 0; }

/* Extrait */
.atd-excerpt { margin-top: 6px; font-size: .88em; line-height: 1.5; }

/* No posts */
.atd-no-posts { color: #888; font-style: italic; }

/* ---- Animations ---- */
@keyframes atd-fadeIn    { from { opacity: 0; }                          to { opacity: 1; } }
@keyframes atd-slideUp   { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
@keyframes atd-slideLeft { from { opacity: 0; transform: translateX(-20px); } to { opacity: 1; transform: translateX(0); } }

.atd-anim { animation-fill-mode: both; }
.atd-anim-fadeIn    { animation-name: atd-fadeIn; }
.atd-anim-slideUp   { animation-name: atd-slideUp; }
.atd-anim-slideLeft { animation-name: atd-slideLeft; }

/* ---- Layouts ---- */
.atd-list    { }
.atd-masonry { column-count: 2; column-gap: 20px; }
.atd-masonry .atd-item { break-inside: avoid; margin-bottom: 20px; }
