@charset "UTF-8";
* { margin: 0; padding: 0; box-sizing: border-box; }

.entry-header { background: none !important; border: none !important; padding: 0 !important; margin: 0 !important; display: block !important; position: static !important; width: auto !important; height: auto !important; box-shadow: none !important; outline: none !important; }

header.entry-header { all: unset !important; display: block !important; }

.post-entry .entry-header { background: none !important; border: none !important; padding: 0 !important; margin: 0 !important; box-shadow: none !important; outline: none !important; }
.post-entry .entry-header h2 { background: none !important; border: none !important; padding: 0 !important; margin: 0 !important; }

.title, .subtitle { background: none !important; border: none !important; padding: 0 !important; margin: 0 !important; box-shadow: none !important; outline: none !important; }

.post-entry .entry-header h2, .blog .entry-header h2 { background: none !important; border: none !important; padding: 0 !important; margin: 0 !important; box-shadow: none !important; outline: none !important; }

body { font-family: 'Open Sans', sans-serif; line-height: 1.6; color: #333; background-color: #f5f5f5; }

header { background-color: #fff; border-bottom: 1px solid #e0e0e0; padding: 1rem 0; position: sticky; top: 0; z-index: 9999; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); isolation: isolate; }
header .container { max-width: 1200px; margin: 0 auto; padding: 0 2rem; display: flex; justify-content: space-between; align-items: center; }
header .name h1 { font-size: 1.5rem; font-weight: 700; }
header .name h1 a { color: #000; text-decoration: none; line-height: 1.2; }
header .name h1 a:hover { color: #3273dc; }
header .navbar ul { display: flex; list-style: none; gap: 2rem; margin: 0; }
header .nav-item { color: #666; text-decoration: none; font-weight: 400; transition: color 0.3s; }
header .nav-item:hover { color: #000; }
header .nav-item.nav-item-active { color: #000; font-weight: 600; }

main.container { max-width: 1200px; margin: 0 auto; padding: 2rem; position: relative; z-index: 1; }

.about { margin-bottom: 3rem; padding: 2rem 0; }
.about h1 { font-size: 2rem; font-weight: 700; margin-bottom: 1rem; }
.about .content p { margin-bottom: 1rem; line-height: 1.8; }
.about .social-links { margin-top: 1.5rem; }
.about .social-links .icon { font-size: 1.8rem; color: #333; margin-right: 1rem; transition: color 0.3s; }
.about .social-links .icon:hover { color: #3273dc; }

h2 { font-size: 2rem; font-weight: 700; margin-bottom: 1.5rem; margin-top: 2rem; }

.title { font-family: 'Open Sans', sans-serif; font-weight: 700; }

.button.is-big { font-size: 1.5rem; /* Taille du texte */ padding: 1rem 1.5rem; /* Espacement interne */ height: auto; /* Laisse le bouton s'étendre */ }

.button.is-big .icon { font-size: 1.75rem; /* Taille de l’icône */ }

.internship-media-grid { display: flex; flex-wrap: wrap; gap: 1rem; margin: 2em 0; }
.internship-media-grid figure { flex: 1; min-width: 300px; margin: 0; }
.internship-media-grid figure img, .internship-media-grid figure video { width: 100%; height: auto; border-radius: 8px; object-fit: cover; }
.internship-media-grid figure figcaption { font-size: 0.9em; color: #666; margin-top: 0.5em; text-align: center; }

.portrait { overflow: hidden; }

.footer .footer-links a { font-size: 25px; color: #000; }

.footer .button.is-small { padding: 0.2rem; height: 2rem; width: 4rem; }

.footer .button.is-small .icon { margin: 0; font-size: 2rem; }

.internships-section, .blog-section, .projects-section, .contact-section { margin-bottom: 3rem; }

.blog-section .entry-header { background: none !important; border: none !important; padding: 0 !important; margin: 0 !important; box-shadow: none !important; outline: none !important; }

.contact-section { padding: 2rem 0; }
.contact-section h1 { font-size: 2.5rem; font-weight: 700; margin-bottom: 1rem; }
.contact-section .contact-intro { font-size: 1.1rem; margin-bottom: 2rem; color: #666; }
.contact-section .contact-list { display: flex; flex-direction: column; gap: 1.5rem; max-width: 700px; }
.contact-section .contact-item { display: flex; align-items: center; gap: 1rem; font-size: 1.1rem; }
.contact-section .contact-item .icon { font-size: 1.5rem; color: #000; min-width: 30px; }
.contact-section .contact-item strong { color: #000; }
.contact-section .contact-item a { color: #000; text-decoration: none; }
.contact-section .contact-item a:hover { text-decoration: underline; }

.inner { margin-bottom: 1.5rem; }

.post-entry { position: relative; padding: 1.5rem; border: 1px solid #e8e8e8; border-radius: 12px; background-color: #fff; cursor: pointer; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04); transition: all 0.3s ease; }
.post-entry:hover { transform: translateY(-2px); box-shadow: 0 8px 25px rgba(0, 0, 0, 0.12); border-color: #3273dc; }
.post-entry .entry-header { background: none !important; border: none !important; padding: 0 !important; margin: 0 0 1rem 0 !important; box-shadow: none !important; outline: none !important; }
.post-entry .entry-header h2 { font-size: 1.4rem; font-weight: 700; margin: 0; color: #1a1a1a; line-height: 1.3; background: none !important; border: none !important; padding: 0 !important; }
.post-entry .entry-content { margin-bottom: 1rem; }
.post-entry .entry-content p { color: #555; line-height: 1.6; margin: 0.5rem 0; font-size: 0.95rem; }
.post-entry .entry-content .location-info { color: #666; font-size: 0.9rem; margin-top: 0.75rem; display: flex; align-items: center; gap: 0.5rem; }
.post-entry .entry-content .location-info i { color: #999; width: 14px; text-align: center; }
.post-entry .entry-footer { font-size: 0.9rem; color: #666; padding-top: 0.75rem; border-top: 1px solid #f0f0f0; }
.post-entry .entry-footer a { color: #3273dc; text-decoration: none; position: relative; z-index: 4; pointer-events: auto; font-weight: 500; transition: color 0.2s ease; }
.post-entry .entry-footer a:hover { color: #1e5bb8; text-decoration: underline; }
.post-entry .entry-link { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 1; cursor: pointer; }

.internships-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 1.5rem; margin-top: 1.5rem; }

.internship-card { position: relative; border: 1px solid #e8e8e8; border-radius: 12px; background-color: #fff; display: flex; flex-direction: column; overflow: hidden; cursor: pointer; transition: all 0.3s ease; z-index: 1; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04); }
.internship-card:hover { transform: translateY(-4px); box-shadow: 0 8px 25px rgba(0, 0, 0, 0.12); border-color: #3273dc; z-index: 2; }
.internship-card .internship-image { width: 100%; height: 160px; overflow: hidden; background-color: #f9f9f9; display: flex; align-items: center; justify-content: center; padding: 1rem; }
.internship-card .internship-image img { max-width: 100%; max-height: 100%; object-fit: contain; }
.internship-card .internship-content { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; gap: 0.75rem; }
.internship-card .entry-header { background: none !important; border: none !important; padding: 0 !important; margin: 0 !important; box-shadow: none !important; outline: none !important; }
.internship-card .entry-header .position-title { font-size: 1.2rem; font-weight: 700; color: #1a1a1a; margin: 0 0 0.5rem 0; line-height: 1.3; background: none !important; border: none !important; padding: 0 !important; }
.internship-card .entry-header .company-name { font-size: 1rem; font-weight: 500; margin: 0; color: #3273dc; background: none !important; border: none !important; padding: 0 !important; }
.internship-card .entry-header .company-name a { color: #3273dc; text-decoration: none; position: relative; z-index: 4; pointer-events: auto; font-weight: 500; transition: color 0.2s ease; }
.internship-card .entry-header .company-name a:hover { color: #1e5bb8; text-decoration: underline; }
.internship-card .entry-content { display: flex; flex-direction: column; gap: 0.5rem; }
.internship-card .entry-content .location-info, .internship-card .entry-content .date-info { color: #666; font-size: 0.9rem; display: flex; align-items: center; gap: 0.5rem; }
.internship-card .entry-content .location-info i, .internship-card .entry-content .date-info i { color: #999; width: 14px; text-align: center; }
.internship-card .entry-link { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 3; cursor: pointer; }

.projects-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.5rem; margin-top: 1.5rem; }

.project-card { position: relative; padding: 1.5rem; border: 1px solid #e8e8e8; border-radius: 12px; background-color: #fff; display: flex; flex-direction: column; min-height: 200px; max-height: 250px; overflow: hidden; cursor: pointer; z-index: 1; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04); transition: all 0.3s ease; }
.project-card:hover { transform: translateY(-4px); box-shadow: 0 8px 25px rgba(0, 0, 0, 0.12); border-color: #3273dc; z-index: 2; }
.project-card .entry-header { background: none !important; border: none !important; padding: 0 !important; margin: 0 0 1rem 0 !important; box-shadow: none !important; outline: none !important; }
.project-card .entry-header h2 { font-size: 1.3rem; font-weight: 700; margin: 0; color: #1a1a1a; line-height: 1.3; background: none !important; border: none !important; padding: 0 !important; }
.project-card .entry-content { flex: 1; margin-bottom: 1rem; overflow: visible; }
.project-card .entry-content p { color: #555; line-height: 1.6; font-size: 0.95rem; margin: 0; }
.project-card .entry-footer { font-size: 0.9rem; color: #666; margin-top: auto; padding-top: 0.75rem; border-top: 1px solid #f0f0f0; }
.project-card .entry-footer a { color: #3273dc; text-decoration: none; position: relative; z-index: 4; pointer-events: auto; font-weight: 500; transition: color 0.2s ease; }
.project-card .entry-footer a:hover { color: #1e5bb8; text-decoration: underline; }
.project-card .entry-footer strong { color: #333; font-weight: 600; }
.project-card .entry-link { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 3; cursor: pointer; }

.project-block .project-title { width: fit-content; margin: 0 !important; font-weight: 600; font-size: 110% !important; }
.project-block .project-title a { color: #000; }
.project-block .project-venue { color: #555; width: fit-content; margin-top: 0; }
.project-block .project-venue-emph { font-style: normal; font-size: 80%; font-weight: 500; color: firebrick; padding-left: 0.25em; }
.project-block .project-awards { color: firebrick; width: fit-content; font-weight: bolder; }
.project-block .project-authors .author-me { color: #000; font-weight: 600; }
.project-block .project-authors a { color: #000 !important; }
.project-block .project-authors a:hover { text-decoration: underline; }
.project-block .project-image { border-radius: 2%; width: 100%; height: 100%; overflow: hidden; font-size: 0; }
.project-block .project-image img { width: 100%; }
.project-block .project-mousecell { position: relative; font-size: 0; }
.project-block .project-mousecell { width: 100%; height: 100%; display: inline-block; overflow: hidden; }
.project-block .project-mousecell video { display: none; }
.project-block .project-description { color: #333; margin: 0.5em 0; }
.project-block .project-links { margin: 0 !important; margin-top: 0.5em !important; }
