@font-face{font-display:swap;font-family:InterVariable;font-style:normal;font-weight:100 900;src:url(../fonts/InterVariable.woff2) format("woff2")}*{box-sizing:border-box;margin:0;padding:0}:root{--bg-color:#fff;--text-color:#000;--text-secondary:#6b7280;--border-color:#e5e7eb;--tag-bg:#f3f4f6;--tag-hover:#e5e7eb;--accent-green:#10b981;--accent-blue:#3b82f6;--sidebar-width:280px;--skill-selected-bg:#000;--skill-selected-text:#fff;--mobile-header-height:80px}@media (prefers-color-scheme:dark){:root{--bg-color:#000;--text-color:#fff;--text-secondary:#9ca3af;--border-color:#1f2937;--tag-bg:#111827;--tag-hover:#1f2937;--skill-selected-bg:#fff;--skill-selected-text:#000}}body{background-color:var(--bg-color);color:var(--text-color);font-family:InterVariable,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased;margin:0;padding:0}body,html{overflow:hidden}html{height:100%}#app{display:flex;height:100vh;overflow:hidden;position:relative;width:100%}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .6s ease-out}.animate-slide-up{animation:slideUp .6s ease-out;animation-fill-mode:both}.delay-1{animation-delay:.1s}.delay-2{animation-delay:.2s}.mobile-header{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:var(--bg-color);border-bottom:1px solid var(--border-color);height:var(--mobile-header-height);left:0;position:fixed;right:0;top:0;z-index:100}.mobile-profile{align-items:center;display:flex;gap:12px;height:100%;padding:16px 20px;position:relative}.mobile-profile img{border-radius:50%;flex-shrink:0;height:40px;-o-object-fit:cover;object-fit:cover;width:40px}.mobile-info{flex:1;min-width:0}.mobile-info h1{font-size:16px;font-weight:600}.mobile-info h1,.mobile-info p{margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-info p{color:var(--text-secondary);font-size:13px}.mobile-actions{align-items:center;display:flex;flex-shrink:0;gap:8px}.mobile-action-btn{align-items:center;background:var(--bg-color);border:1px solid var(--border-color);border-radius:6px;color:var(--text-color);display:flex;height:32px;justify-content:center;text-decoration:none;transition:all .2s ease;width:32px}@media (hover:hover){.mobile-action-btn:hover{background:var(--tag-bg);transform:translateY(-1px)}}.sidebar{border-right:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0;justify-content:space-between;overflow-y:auto;padding:40px 30px;width:var(--sidebar-width)}.profile-section{text-align:center}.profile-image{height:100px;margin:0 auto 20px;width:100px}.profile-image img{border-radius:50%;height:100%;-o-object-fit:cover;object-fit:cover;width:100%}.name{font-size:24px;font-weight:700}.name,.title{margin-bottom:4px}.title{font-size:16px}.status,.title{color:var(--text-secondary)}.status{font-size:14px;font-weight:500;margin-bottom:24px}.contact-links{gap:8px;margin-bottom:24px}.contact-item,.contact-links{display:flex;justify-content:center}.contact-item{align-items:center;border:1px solid var(--border-color);border-radius:8px;color:var(--text-color);height:40px;text-decoration:none;transition:all .2s ease;width:40px}@media (hover:hover){.contact-item:hover{background:var(--tag-bg);transform:translateY(-2px)}}.personal-info{color:var(--text-secondary);display:flex;flex-direction:column;font-size:13px;gap:8px}.info-link{color:inherit;text-decoration:none;transition:color .2s ease}@media (hover:hover){.info-link:hover{color:var(--text-color)}}.sidebar-nav{display:flex;flex-direction:column;gap:4px;margin-top:40px}.nav-item{background:none;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;font-size:14px;font-weight:500;padding:12px 20px;text-align:left;transition:all .2s ease}@media (hover:hover){.nav-item:hover{background:var(--tag-bg);color:var(--text-color)}}.main-content{flex:1;overflow-x:hidden;overflow-y:auto;padding:40px 60px 40px 40px;-webkit-overflow-scrolling:touch;height:100vh;position:relative}.section{margin-bottom:80px;margin-right:0;max-width:1000px}.section-title{font-size:32px;font-weight:800;letter-spacing:-.5px;margin-bottom:40px}.skills-stack{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-start;max-width:700px;padding:0}.skill-tag{background:var(--tag-bg);border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;padding:6px 10px;transition:all .2s ease;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.skill-tag.skill-selected{background:var(--skill-selected-bg);color:var(--skill-selected-text)}@media (hover:hover){.skill-tag:hover{background:var(--tag-hover)}.skill-tag.skill-selected:hover{background:var(--skill-selected-bg);color:var(--skill-selected-text)}}.projects-container{display:flex;flex-direction:column;gap:20px}.project-card{background:var(--bg-color);border:1px solid var(--border-color);border-radius:12px;padding:24px;transition:all .3s ease}@media (hover:hover){.project-card:hover{border-color:var(--text-secondary);transform:translateY(-2px)}}.project-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.project-header h3{font-size:20px;font-weight:700;margin-bottom:4px}.project-type{border-radius:4px;flex-shrink:0;font-size:10px;font-weight:700;letter-spacing:.5px;padding:4px 8px}.project-type.personnel{background:#10b98126;color:#047857}.project-type.académique{background:#3b82f626;color:#1d4ed8}.project-type.professionnel{background:#8b5cf626;color:#7c3aed}@media (prefers-color-scheme:dark){.project-type.personnel{background:#34d39926;color:#34d399}.project-type.académique{background:#60a5fa26;color:#60a5fa}.project-type.professionnel{background:#a78bfa26;color:#a78bfa}}.project-description{color:var(--text-secondary);font-size:15px;line-height:1.6;margin-bottom:20px}.project-footer{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between}.skill-tags{display:flex;flex-wrap:wrap;gap:6px}.project-links{display:flex;gap:12px}.project-link{align-items:center;color:var(--text-secondary);display:flex;font-size:13px;gap:4px;text-decoration:none;transition:all .2s ease}@media (hover:hover){.project-link:hover{color:var(--text-color)}}.education-container{display:flex;flex-direction:column;gap:20px}.education-card{background:var(--bg-color);border:1px solid var(--border-color);border-radius:12px;padding:24px;transition:all .3s ease}@media (hover:hover){.education-card:hover{border-color:var(--text-secondary);transform:translateY(-2px)}}.education-period{color:var(--text-secondary);display:block;font-size:13px;margin-bottom:8px}.education-card h3{font-size:20px;font-weight:700;margin-bottom:4px}.education-school{color:var(--text-color);font-size:16px;margin-bottom:8px}.education-description{color:var(--text-secondary);font-size:15px}.education-skill-tags{margin-top:12px}@media (max-width:768px){body{height:auto}#app,body{position:relative}#app{flex-direction:column;height:100vh}.sidebar{display:none}.main-content{height:100vh;overflow-x:hidden;overflow-y:auto;padding:calc(var(--mobile-header-height) + 20px) 20px 40px;-webkit-overflow-scrolling:touch;transform:translateZ(0);will-change:scroll-position}.section{margin-bottom:60px}.section-title{font-size:24px;margin-bottom:24px}.skills-stack{justify-content:center;margin:0 auto;padding:0}.education-card,.project-card{padding:20px}.project-footer{align-items:flex-start;flex-direction:column}}@supports (padding:max(0px)){@media (max-width:768px){.main-content{padding-bottom:max(40px,env(safe-area-inset-bottom) + 20px)}}}@media (max-width:768px) and (-webkit-min-device-pixel-ratio:2){.main-content{padding-bottom:calc(40px + env(safe-area-inset-bottom))}}::selection{background:var(--text-color);color:var(--bg-color)}::-moz-selection{background:var(--text-color);color:var(--bg-color)}a:focus-visible,button:focus-visible{outline:2px solid var(--text-color);outline-offset:2px}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.main-content{scroll-behavior:auto}}
