/* Blog Enhanced CSS - Style moderne mais épuré */

/* Variables */
:root {
    --blog-bg: #121212;
    --blog-text: #e0e0e0;
    --blog-accent: #989898; /* Note: Screenshot shows a purple accent for buttons/links, this variable is grey. */
    --blog-accent-light: #dfdfdf;
    --blog-card-bg: rgba(30, 30, 30, 0.7);
    --blog-border: rgba(255, 255, 255, 0.1);
}

/* Styles de base */
.blog-container {
    max-width: 1300px; /* MODIFIED: Increased max-width for a slightly wider content column */
    margin: 0 auto;
    padding: 20px;
}

.blog-header {
    margin-bottom: 40px;
    text-align: center;
}

.blog-title {
    font-size: 2.5rem;
    margin-bottom: 10px;
    color: var(--blog-accent-light);
}

.blog-subtitle {
    font-size: 1.2rem;
    opacity: 0.8;
    margin-bottom: 20px;
}

/* Filtres et navigation */
.blog-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    margin-bottom: 30px;
    justify-content: center;
    align-items: center;
}

.blog-filter-group {
    display: flex;
    align-items: center;
}

.blog-filter-label {
    margin: 0 10px; /* MODIFIED: Reduced margin */
    font-weight: 500;
    font-size: 0.9rem; /* ADDED: Made label text slightly smaller */
}

.blog-filter-select {
    width: 1.6vw;
    background-color: var(--blog-card-bg);
    color: var(--blog-text);
    border: 1px solid var(--blog-border);
    padding: 6px 10px; /* MODIFIED: Reduced padding */
    border-radius: 4px;
    min-width: 130px; /* MODIFIED: Reduced min-width */
    font-size: 0.9rem; /* ADDED: Made select text slightly smaller */
}

.blog-filter-select:focus {
    outline: none;
    border-color: var(--blog-accent);
}

.blog-filter-button {
    background-color: var(--blog-accent);
    color: white;
    border: none;
    padding: 7px 12px; /* MODIFIED: Reduced padding for smaller size & vertical alignment with select */
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.2s;
    font-size: 0.9rem; /* ADDED: Made button text slightly smaller */
    margin: 0 10px;
}

.blog-filter-button:hover {
    background-color: var(--blog-accent-light);
}

.blog-rss-link {
    display: flex;
    align-items: center;
    color: var(--blog-text);
    text-decoration: none;
    /* margin-left: auto; */ /* REMOVED: To allow it to be part of the centered flex group */
    font-size: 0.9rem; /* ADDED: Consistent font size */
}

.blog-rss-link svg {
    margin-right: 5px;
    fill: var(--blog-accent);
}

.blog-rss-link:hover {
    color: var(--blog-accent-light);
}

/* Grille de posts */
.blog-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 25px;
    margin-bottom: 40px;
}

/* Carte de post */
.blog-card {
    background-color: var(--blog-card-bg);
    border-radius: 8px;
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    height: 100%;
    display: flex;
    flex-direction: column;
    border: 1px solid var(--blog-border);
}

.blog-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.2);
}

.blog-card-image {
    width: 100%;
    height: 180px;
    overflow: hidden;
}

.blog-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.blog-card:hover .blog-card-image img {
    transform: scale(1.05);
}

.blog-card-content {
    padding: 20px;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
}

.blog-card-title {
    font-size: 1.4rem;
    margin-bottom: 10px;
    line-height: 1.3;
}

.blog-card-title a {
    color: var(--blog-text);
    text-decoration: none;
    transition: color 0.2s;
}

.blog-card-title a:hover {
    color: var(--blog-accent-light);
}

.blog-card-meta {
    font-size: 0.9rem;
    color: rgba(255, 255, 255, 0.6);
    margin-bottom: 15px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
}

.blog-card-meta-item {
    display: flex;
    align-items: center;
}

.blog-card-meta-item svg {
    width: 16px;
    height: 16px;
    margin-right: 5px;
    fill: currentColor;
}

.blog-card-excerpt {
    margin-bottom: 20px;
    line-height: 1.6;
    flex-grow: 1;
}

.blog-card-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: auto;
}

.blog-card-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}

.blog-card-tag {
    background-color: rgba(156, 39, 176, 0.2);
    color: var(--blog-accent-light);
    padding: 3px 8px;
    border-radius: 3px;
    font-size: 0.8rem;
}

.blog-card-stats {
    display: flex;
    gap: 15px;
}

.blog-card-stat {
    display: flex;
    align-items: center;
    font-size: 0.9rem;
    color: rgba(255, 255, 255, 0.7);
}

.blog-card-stat svg {
    width: 16px;
    height: 16px;
    margin-right: 5px;
    fill: currentColor;
}

.blog-read-more {
    display: inline-block;
    margin-top: 15px;
    color: var(--blog-accent-light);
    text-decoration: none;
    font-weight: 500;
    transition: color 0.2s;
}

.blog-read-more:hover {
    color: white;
}

/* Post détaillé */
.blog-post {
    background-color: var(--blog-card-bg);
    border-radius: 8px;
    padding: 30px;
    margin-bottom: 40px;
    border: 1px solid var(--blog-border);
}

.blog-post-header {
    margin-bottom: 30px;
}

.blog-post-title {
    font-size: 2.2rem;
    margin-bottom: 15px;
    line-height: 1.3;
}

.blog-post-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    margin-bottom: 20px;
    color: rgba(255, 255, 255, 0.7);
    font-size: 0.95rem;
}

.blog-post-meta-item {
    display: flex;
    align-items: center;
}

.blog-post-meta-item svg {
    width: 18px;
    height: 18px;
    margin-right: 6px;
    fill: currentColor;
}

.blog-post-meta-item a {
    color: var(--blog-accent-light);
    text-decoration: none;
}

.blog-post-meta-item a:hover {
    text-decoration: underline;
}

.blog-post-cover {
    width: 100%;
    max-height: 500px;
    overflow: hidden;
    border-radius: 6px;
    margin-bottom: 30px;
}

.blog-post-cover img {
    width: 100%;
    height: auto;
}

.blog-post-content {
    line-height: 1.8;
    font-size: 1.1rem;
    margin-bottom: 40px;
}

.blog-post-content p {
    margin-bottom: 20px;
}

.blog-post-content h2 {
    font-size: 1.8rem;
    margin: 40px 0 20px;
    color: var(--blog-accent-light);
}

.blog-post-content h3 {
    font-size: 1.5rem;
    margin: 30px 0 15px;
}

.blog-post-content img {
    max-width: 100%;
    height: auto;
    border-radius: 6px;
    margin: 20px 0;
}

.blog-post-content pre, .blog-post-content code {
    background-color: rgba(0, 0, 0, 0.3);
    border-radius: 4px;
    padding: 15px;
    overflow-x: auto;
    margin: 20px 0;
    font-family: 'Courier New', monospace;
}

.blog-post-content blockquote {
    border-left: 4px solid var(--blog-accent);
    padding-left: 20px;
    margin-left: 0;
    font-style: italic;
    color: rgba(255, 255, 255, 0.8);
}

.blog-post-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 30px;
}

.blog-post-tag {
    background-color: rgba(156, 39, 176, 0.2);
    color: var(--blog-accent-light);
    padding: 5px 12px;
    border-radius: 4px;
    font-size: 0.9rem;
    text-decoration: none;
    transition: background-color 0.2s;
}

.blog-post-tag:hover {
    background-color: rgba(156, 39, 176, 0.4);
}

/* Actions (like, comment) */
.blog-post-actions {
    display: flex;
    gap: 15px;
    margin-bottom: 30px;
}

.blog-post-action {
    display: flex;
    align-items: center;
    background-color: rgba(255, 255, 255, 0.1);
    border: none;
    padding: 8px 15px;
    border-radius: 4px;
    color: var(--blog-text);
    cursor: pointer;
    transition: background-color 0.2s;
    font-size: 1rem;
}

.blog-post-action svg {
    width: 20px;
    height: 20px;
    margin-right: 8px;
    fill: currentColor;
}

.blog-post-action:hover {
    background-color: rgba(255, 255, 255, 0.2);
}

.blog-post-action.liked {
    background-color: rgba(82, 12, 95, 0.3);
    color: var(--blog-accent-light);
}

/* Commentaires */
.blog-comments {
    margin-top: 40px;
}

.blog-comments-title {
    font-size: 1.5rem;
    margin-bottom: 20px;
    display: flex;
    align-items: center;
}

.blog-comments-title svg {
    width: 24px;
    height: 24px;
    margin-right: 10px;
    fill: var(--blog-accent-light);
}

.blog-comment-form {
    margin-bottom: 30px;
}

.blog-comment-form textarea {
    width: 100%;
    background-color: rgba(0, 0, 0, 0.2);
    border: 1px solid var(--blog-border);
    border-radius: 4px;
    padding: 15px;
    color: var(--blog-text);
    font-size: 1rem;
    min-height: 100px;
    margin-bottom: 15px;
    resize: vertical;
}

.blog-comment-form textarea:focus {
    outline: none;
    border-color: var(--blog-accent);
}

.blog-comment-form button {
    background-color: var(--blog-accent);
    color: white;
    border: none;
    padding: 10px 20px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 1rem;
    transition: background-color 0.2s;
}

.blog-comment-form button:hover {
    background-color: var(--blog-accent-light);
}

.blog-comment-list {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.blog-comment {
    background-color: rgba(0, 0, 0, 0.2);
    border-radius: 6px;
    padding: 20px;
    border: 1px solid var(--blog-border);
}

.blog-comment-header {
    display: flex;
    justify-content: space-between;
    margin-bottom: 10px;
}

.blog-comment-author {
    font-weight: 500;
}

.blog-comment-date {
    font-size: 0.9rem;
    color: rgba(255, 255, 255, 0.6);
}

.blog-comment-content {
    line-height: 1.6;
}

/* Pagination */
.blog-pagination {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: 40px;
}

.blog-pagination-item {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--blog-card-bg);
    border: 1px solid var(--blog-border);
    border-radius: 4px;
    color: var(--blog-text);
    text-decoration: none;
    transition: all 0.2s;
}

.blog-pagination-item:hover {
    background-color: rgba(156, 39, 176, 0.2);
    border-color: var(--blog-accent);
}

.blog-pagination-item.active {
    background-color: var(--blog-accent);
    border-color: var(--blog-accent);
}

.blog-pagination-item.disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* Responsive */
@media (max-width: 768px) {
    .blog-grid {
        grid-template-columns: 1fr;
    }
    
    .blog-filters {
        flex-direction: column;
        align-items: stretch;
    }
    
    .blog-filter-group {
        width: 100%;
    }
    
    .blog-filter-select {
        width: 20px;
    }
    
    .blog-post-title {
        font-size: 1.8rem;
    }
    
    .blog-post-meta {
        flex-direction: column;
        gap: 8px;
    }
    .blog-filters {
        flex-direction: column;     /* Override: Arrange form and RSS link in a row */
        flex-wrap: nowrap;       /* Override: Prevent wrapping to new line */
        align-items: center;     /* Align items vertically in the center */
        justify-content: flex-start; /* Align items to the start, relies on overflow-x */
        gap: 10px;               /* Space between the form and the RSS link */
        overflow-x: auto;        /* Allow horizontal scrolling if filters + RSS don't fit */
        padding-bottom: 10px;    /* Add some padding at the bottom for the scrollbar */
        margin-bottom: 20px;     /* Optionally adjust margin */
    }

    .fform{
        flex-direction: row;
        flex-grow: 1;
        overflow: hidden;
        flex-wrap: nowrap;
    }

    .blog-filter-label{
        display: none;
    }

}

/* Widget de posts récents pour la page d'accueil */
.blog-recent-posts-widget {
    background-color: var(--blog-card-bg);
    border-radius: 8px;
    padding: 20px;
    margin-bottom: 30px;
    border: 1px solid var(--blog-border);
}

.blog-widget-title {
    font-size: 1.5rem;
    margin-bottom: 20px;
    color: var(--blog-accent-light);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.blog-widget-title a {
    font-size: 0.9rem;
    color: var(--blog-text);
    text-decoration: none;
    transition: color 0.2s;
}

.blog-widget-title a:hover {
    color: var(--blog-accent-light);
}

.blog-widget-posts {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.blog-widget-post {
    display: flex;
    gap: 15px;
    padding-bottom: 15px;
    border-bottom: 1px solid var(--blog-border);
}

.blog-widget-post:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.blog-widget-post-image {
    width: 80px;
    height: 80px;
    border-radius: 4px;
    overflow: hidden;
    flex-shrink: 0;
}

.blog-widget-post-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.blog-widget-post-content {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
}

.blog-widget-post-title {
    font-size: 1rem;
    margin-bottom: 5px;
    line-height: 1.3;
}

.blog-widget-post-title a {
    color: var(--blog-text);
    text-decoration: none;
    transition: color 0.2s;
}

.blog-widget-post-title a:hover {
    color: var(--blog-accent-light);
}

.blog-widget-post-meta {
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.6);
    margin-bottom: 5px;
}

.blog-widget-post-excerpt {
    font-size: 0.9rem;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
/* Media Queries pour la responsivité */
@media (max-width: 1200px) {
    .blog-container {
        max-width: 95%;
    }
}

@media (max-width: 992px) {
    .blog-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .blog-post-title {
        font-size: 2rem;
    }
    
    .blog-post {
        padding: 20px;
    }
}

@media (max-width: 768px) {
    .blog-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    
    .blog-filters {
        display: flex;
        flex-direction: column;    /* Main change: ensure filters are in a row */
        flex-wrap: nowrap;      /* Prevent wrapping of form and RSS link */
        align-items: center;    /* Vertically align items in the filter bar */
        width: 100%;            /* Filter bar takes full available width */
        gap: 8px;               /* Reduced gap between the form and the RSS link */
        margin-bottom: 20px;
        /* overflow-x: auto; /* REMOVED to prevent scrolling of the filter bar itself */
    }

    /* The form containing the filter dropdowns and button */
    .blog-filters .fform { /* Targets form with class 'fform' inside .blog-filters */
        display: flex;          /* Ensure it's flex (already inline, but good practice) */
        flex-direction: row;
        flex-wrap: nowrap;      /* Keep filter groups and button in a single line */
        align-items: center;
        flex-grow: 1;           /* Form takes up available space */
        min-width: 0;           /* Allows the form to shrink if needed */
        gap: 5px;               /* Space between filter groups and the button */
        /* overflow: hidden; /* Optional: if you want to strictly clip content within the form */
    }

    .blog-filter-group {
        display: flex;          /* Ensures label (if shown) and select are in line */
        align-items: center;
        flex-grow: 1;           /* Each filter group will share space equally */
        flex-shrink: 1;         /* Allow groups to shrink */
        flex-basis: 0;          /* Distribute space starting from zero */
        min-width: 0;           /* Allow group to shrink below content size if necessary */
        /* Remove width: 100%; and flex-direction: column; from previous mobile attempts */
    }

    .blog-filter-label {
        display: none;          /* Hide labels on mobile to save space */
        /* If you were to keep labels:
        font-size: 0.75rem;
        margin-right: 4px;
        white-space: nowrap;
        */
    }

    .blog-filter-select {
        width: 100%;            /* Select takes full width of its parent .blog-filter-group */
        min-width: 70px;        /* Minimum width to keep selects usable. Adjust as needed. */
        padding: 6px 8px;       /* Reduced padding */
        font-size: 0.7rem;      /* Reduced font size */
        height: auto;           /* Auto height based on content and padding */
        box-sizing: border-box; /* Ensures padding/border are included in width/height */
        /* Remove fixed width like width: 20px; or margin-left if it was for stacking */
    }

    .blog-filter-button {
        padding: 7px 10px;      /* Adjusted padding */
        font-size: 0.8rem;      /* Reduced font size */
        flex-shrink: 0;         /* Prevent button from shrinking disproportionately */
        /* Remove width: 100%; and margin-top if they were for stacking */
    }

    .blog-rss-link {
        flex-shrink: 0;         /* Prevent RSS link from shrinking too much initially */
        font-size: 0.8rem;      /* Reduced font size */
        white-space: nowrap;    /* Prevent text from wrapping, helps in fitting */
        /* If still too wide on very small screens, consider hiding text: */
        /* .blog-rss-link span { display: none; } */
        /* .blog-rss-link svg { margin-right: 0; } */
        /* Remove margin-left: 0; margin-top: 10px; justify-content: center; if from stacking attempts */
    }
    
    .blog-rss-link {
        margin-left: 0;
        margin-top: 10px;
        justify-content: center;
    }
    
    .blog-post-title {
        font-size: 1.8rem;
    }
    
    .blog-post-meta {
        flex-direction: column;
        gap: 8px;
    }
    
    .blog-post-actions {
        flex-direction: column;
        gap: 10px;
    }
    
    .blog-post-action {
        width: 100%;
        justify-content: center;
    }
    
    .blog-comment-header {
        flex-direction: column;
        gap: 5px;
    }
}

@media (max-width: 480px) {
    .blog-container {
        padding: 15px 10px;
    }
    
    .blog-title {
        font-size: 2rem;
    }
    
    .blog-subtitle {
        font-size: 1rem;
    }
    
    .blog-card {
        border-radius: 6px;
    }
    
    .blog-card-image {
        height: 150px;
    }
    
    .blog-card-content {
        padding: 15px;
    }
    
    .blog-card-title {
        font-size: 1.2rem;
    }
    
    .blog-post {
        padding: 15px;
        border-radius: 6px;
    }
    
    .blog-post-title {
        font-size: 1.5rem;
    }
    
    .blog-post-content {
        font-size: 1rem;
    }
    
    .blog-post-content h2 {
        font-size: 1.4rem;
    }
    
    .blog-post-content h3 {
        font-size: 1.2rem;
    }
    
    .blog-comment {
        padding: 15px;
    }
    
    .blog-comment-form textarea {
        min-height: 80px;
    }
    
    .blog-widget-post {
        flex-direction: column;
        gap: 10px;
    }
    
    .blog-widget-post-image {
        width: 100%;
        height: 120px;
    }
}

/* Optimisations pour les appareils tactiles */
@media (hover: none) {
    .blog-card:hover {
        transform: none;
    }
    
    .blog-card:hover .blog-card-image img {
        transform: none;
    }
    
    .blog-card-title a:active,
    .blog-post-tag:active,
    .blog-read-more:active,
    .blog-post-action:active {
        opacity: 0.7;
    }
    

}

/* Mode sombre optimisé */
@media (prefers-color-scheme: dark) {
    :root {
        --blog-bg: #121212;
        --blog-text: #e0e0e0;
        --blog-accent: #9e9e9e;
        --blog-accent-light: #dadada;
        --blog-card-bg: rgba(30, 30, 30, 0.7);
        --blog-border: rgba(255, 255, 255, 0.1);
    }
}

/* Mode clair (si nécessaire) */
@media (prefers-color-scheme: light) {
    :root {
        --blog-bg: #f5f5f5;
        --blog-text: #212121;
        --blog-accent: #9e9e9e;
        --blog-accent-light: #dadada;
        --blog-card-bg: rgba(255, 255, 255, 0.7);
        --blog-border: rgba(0, 0, 0, 0.1);
    }
    
    .blog-card,
    .blog-post,
    .blog-comment,
    .blog-recent-posts-widget {
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    }
}
