/* Mise en page & responsive */
body {
    font-family: Arial, sans-serif;
    padding: 20px;
    max-width: 50%;
    margin: auto;
}
@media (max-width: 900px) {
    body { max-width: 100%; padding: 10px; }
}

/* Titre */
h1 {
    margin-bottom: 20px;
    display: flex;
    align-items: center;
    gap: 10px;
    color: #333;
}

/* Liste */
ul {
    list-style: none;
    padding: 0;
    margin: 0;
    border: 1px solid #ddd;
    border-radius: 5px;
    overflow: hidden;
}
li {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px;
    border-bottom: 1px solid #ddd;
}
li:last-child { border-bottom: none; }

/* Lien principal (image + infos) */
a.item {
    display: flex;
    align-items: center;
    text-decoration: none;
    color: inherit;
    flex: 1;
    min-width: 0;
}
li:hover a.item { background: #f7f7f7; }

/* Miniature */
img {
    width: 50px;
    height: 50px;
    object-fit: contain;
    margin-right: 15px;
    border: 1px solid #ccc;
    background: #fff;
    padding: 2px;
    border-radius: 4px;
    flex-shrink: 0;
}

/* Infos texte */
.info { display: flex; flex-direction: column; min-width: 0; }
.name {
    font-weight: bold;
    color: #0066cc;
    margin-bottom: 3px;
    display: flex;
    align-items: center;
    gap: 8px;
}
.details { font-size: 0.9em; color: #555; }

/* Bouton télécharger (à droite) */
.download-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border: 1px solid #ddd;
    border-radius: 6px;
    text-decoration: none;
    color: #333;
    flex-shrink: 0;
}
.download-btn:hover {
    background: #f0f0f0;
    border-color: #ccc;
}

/* Résumé bas de page */
.summary {
    margin-top: 12px;
    font-size: 0.95em;
    color: #333;
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Erreur */
.error { color: #c00; }
