/* ========================
   Container général
   ======================== */
   .contact .container {
    max-width: 900px;
    margin: 0 auto;
    padding: 20px;
}

/* ========================
   Titres et sous-titres
   ======================== */
.contact .section-title {
    font-size: clamp(1.5rem, 2.5vw, 2em);
    font-weight: bold;
    color: #222;
    text-align: center;
    margin-bottom: 5px;
}

.contact .section-subtitle {
    font-size: clamp(1rem, 2vw, 1.2em);
    color: #555;
    text-align: center;
    margin-bottom: 25px;
}

/* ========================
   Publications
   ======================== */
.publications-list {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

/* Card publication */
.publication-item {
    background-color: #fff;
    border-left: 5px solid #ff6366; /* accent moderne */
    border-radius: 8px;
    box-shadow: 0 2px 6px rgba(0,0,0,0.05);
    padding: 15px 20px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.publication-item:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 15px rgba(0,0,0,0.08);
}

/* Header de chaque publication */
.pub-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.pub-type {
    font-weight: 700;
    color: #ff637a;
}

.pub-date {
    font-size: 1.2rem;
    color: #888;
}

/* Liste à puces moderne */
.pub-details {
    list-style: none;
    padding-left: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.pub-details li {
    position: relative;
    padding-left: 15px;
    font-size: clamp(0.9rem, 1.2vw, 1rem);
    color: #333;
}

/* Puce moderne */
.pub-details li::before {
    content: "•";
    position: absolute;
    left: 0;
    color: #6c63ff;
    font-weight: bold;
}

/* ========================
   Responsive
   ======================== */
@media (max-width: 768px) {
    .contact .container {
        padding: 15px;
    }
    .pub-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 5px;
    }
}
