/**
 * Admin — Articles et catégories
 */

.page-admin-articles .subtitle,
.page-admin-categories .subtitle {
    color: var(--text-muted);
    font-size: 0.88rem;
    margin-bottom: 1.5rem;
}

/* Liste catégories */
.cat-list {
    list-style: none;
    padding: 0;
    margin: 0 0 1.5rem;
}

.cat-list li {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.6rem 0.75rem;
    background: var(--card-bg, rgba(255,255,255,0.04));
    border-radius: var(--radius, 6px);
    margin-bottom: 0.5rem;
    border: 1px solid var(--border, rgba(255,255,255,0.08));
}

.cat-list li .cat-order {
    display: flex;
    flex-direction: column;
    gap: 0;
}
.cat-list li .cat-order .cat-btn-move {
    padding: 0.15rem 0.35rem;
    font-size: 0.75rem;
    border: none;
    background: transparent;
    color: var(--text-muted);
    cursor: pointer;
}
.cat-list li .cat-order .cat-btn-move:hover { color: var(--text); }

.cat-list li .cat-name { flex: 1; font-weight: 500; }
.cat-list li .cat-slug { color: var(--text-muted); font-size: 0.85rem; }
.cat-list li .cat-actions { display: flex; gap: 0.5rem; }
.cat-list li .cat-actions button {
    padding: 0.35rem 0.6rem;
    font-size: 0.8rem;
    border-radius: var(--radius, 6px);
    border: 1px solid var(--border);
    background: transparent;
    color: var(--text-muted);
    cursor: pointer;
}
.cat-list li .cat-actions button:hover { color: var(--text); background: rgba(255,255,255,0.06); }
.cat-list li .cat-actions button.delete:hover { color: var(--error, #e57373); border-color: var(--error); }

/* Bouton ajouter */
.btn-add-cat, .btn-add-art {
    margin-bottom: 1rem;
}

/* Modal / formulaire inline catégorie */
.cat-form-wrap {
    display: none;
    margin-bottom: 1rem;
    padding: 1rem;
    background: var(--card-bg, rgba(255,255,255,0.04));
    border-radius: var(--radius);
    border: 1px solid var(--border);
}
.cat-form-wrap.is-open { display: block; }
.cat-form-wrap label { display: block; margin-bottom: 0.25rem; font-size: 0.88rem; color: var(--text-muted); }
.cat-form-wrap input { width: 100%; max-width: 320px; padding: 0.5rem; margin-bottom: 0.75rem; border-radius: var(--radius); border: 1px solid var(--border); background: var(--input-bg); color: var(--text); }
.cat-form-wrap .form-actions { margin-top: 0.75rem; display: flex; gap: 0.5rem; }

/* Liste articles */
.art-list { margin: 0; padding: 0; list-style: none; }
.art-list li {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem;
    border-bottom: 1px solid var(--border);
}
.art-list li .art-title { flex: 1 1 200px; font-weight: 500; }
.art-list li .art-meta { font-size: 0.85rem; color: var(--text-muted); }
.art-list li .art-status { font-size: 0.8rem; padding: 0.2rem 0.5rem; border-radius: 4px; }
.art-list li .art-status.draft { background: rgba(255,193,7,0.2); color: #ffc107; }
.art-list li .art-status.published { background: rgba(76,175,80,0.2); color: #81c784; }
.art-list li .art-actions { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.art-list li .art-actions a, .art-list li .art-actions button {
    padding: 0.35rem 0.6rem;
    font-size: 0.8rem;
    border-radius: var(--radius);
    text-decoration: none;
    border: 1px solid var(--border);
    background: transparent;
    color: var(--text-muted);
    cursor: pointer;
}
.art-list li .art-actions a:hover, .art-list li .art-actions button:hover { color: var(--text); background: rgba(255,255,255,0.06); }

/* Filtres liste articles */
.art-filters { display: flex; flex-wrap: wrap; gap: 0.75rem; align-items: center; margin-bottom: 1rem; }
.art-filters select { padding: 0.5rem; border-radius: var(--radius); border: 1px solid var(--border); background: var(--input-bg); color: var(--text); }

/* Formulaire édition article */
.article-edit-form .field { margin-bottom: 1rem; }
.article-edit-form label { display: block; margin-bottom: 0.25rem; font-size: 0.88rem; color: var(--text-muted); }
.article-edit-form input[type="text"], .article-edit-form input[type="url"], .article-edit-form select, .article-edit-form textarea {
    width: 100%;
    max-width: 560px;
    padding: 0.5rem;
    border-radius: var(--radius);
    border: 1px solid var(--border);
    background: var(--input-bg);
    color: var(--text);
}
.article-edit-form textarea.meta-desc { min-height: 60px; }
.article-edit-form .banner-preview { max-width: 100%; max-height: 200px; object-fit: cover; border-radius: var(--radius); margin-top: 0.5rem; }
.article-edit-form .banner-zone { margin-bottom: 1rem; }
#quill-editor { min-height: 200px; background: var(--input-bg); }
.ql-editor { min-height: 180px; }
.article-edit-form .form-actions { margin-top: 1.5rem; display: flex; gap: 0.75rem; flex-wrap: wrap; }

/* Page article publique — bandeau */
.article-page .article-banner-wrap {
    width: 100%;
    max-width: 100%;
    margin: 0 auto 1.5rem;
    border-radius: var(--radius, 6px);
    overflow: hidden;
    aspect-ratio: 21/9;
    max-height: 40vh;
    background: var(--card-bg);
}
.article-page .article-banner-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.article-page .article-meta { color: var(--text-muted); font-size: 0.88rem; margin-bottom: 1rem; }
.article-page .article-body { line-height: 1.6; }
.article-page .article-body p {
    margin: 0.35em 0;
}
.article-page .article-body p:first-child { margin-top: 0; }
.article-page .article-body p:last-child { margin-bottom: 0; }
.article-page .article-body img { max-width: 100%; height: auto; }

/* ─── Page publique liste articles (liste mixte + pagination) ───────────────── */
.page-articles-public {
    padding: 0.5rem 0.5rem 1rem;
    max-width: 1100px;
    margin: 0 auto;
}
.articles-public-subtitle {
    color: var(--text-muted);
    font-size: 0.88rem;
    margin-bottom: 1.5rem;
}
.articles-empty {
    color: var(--text-muted);
}
.articles-mixed-list {
    list-style: none;
    padding: 0;
    margin: 0 0 2rem;
}
.articles-mixed-item {
    border-bottom: 1px solid var(--border);
}
.articles-mixed-link {
    display: flex;
    gap: 1rem;
    padding: 1rem 0;
    text-decoration: none;
    color: inherit;
    align-items: flex-start;
}
.articles-mixed-link:hover .articles-mixed-title {
    color: var(--accent);
}
.articles-mixed-thumb {
    flex-shrink: 0;
    width: 160px;
    height: 90px;
    border-radius: var(--radius, 6px);
    overflow: hidden;
    background: var(--card-bg, rgba(255,255,255,0.04));
}
.articles-mixed-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.articles-mixed-thumb--placeholder {
    background: var(--border);
}
.articles-mixed-content {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}
.articles-mixed-title {
    font-family: var(--font-title);
    font-size: 1.05rem;
    transition: color 0.15s;
}
.articles-mixed-excerpt {
    font-size: 0.88rem;
    color: var(--text-muted);
    line-height: 1.4;
    display: -webkit-box;
    line-clamp: 2;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.articles-mixed-meta {
    font-size: 0.8rem;
    color: var(--text-muted);
}
.articles-mixed-meta span + span::before {
    content: " · ";
}
.articles-pagination {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border);
}
.articles-pagination-info {
    font-size: 0.88rem;
    color: var(--text-muted);
}
.articles-pagination-links {
    display: flex;
    gap: 0.5rem;
}
@media (max-width: 480px) {
    .articles-mixed-thumb {
        width: 100px;
        height: 56px;
    }
}
