:root{--bg: #f8f9fb;--surface: #ffffff;--surface-hover: #f1f5f9;--border: #e5e7eb;--accent: #7c3aed;--accent-dark: #6d28d9;--text-primary: #111827;--text-secondary: #6b7280;--text-muted: #9ca3af;--shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);--shadow-lg: 0 12px 32px rgba(0,0,0,.1);--radius: 10px;--header-h: 64px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;font-weight:400;color-scheme:light;color:var(--text-primary);background-color:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}body{display:flex;place-items:center;min-width:320px;min-height:100vh;background-color:var(--bg)}h1,h2,h3,h4,h5,h6{margin:0;font-family:Plus Jakarta Sans,-apple-system,sans-serif;font-weight:700;line-height:1.2;color:var(--text-primary)}h1{font-size:2.5em}h2{font-size:1.5em}h3{font-size:1.2em}h4{font-size:1em}p{margin:0;color:var(--text-secondary)}a{font-weight:500;color:var(--accent);text-decoration:none;transition:color .2s ease}a:hover{color:var(--accent-dark)}button{border-radius:var(--radius);border:1.5px solid var(--accent);padding:.6em 1.4em;font-size:.9em;font-weight:600;font-family:inherit;background-color:var(--accent);color:#fff;cursor:pointer;transition:all .2s ease}button:hover{background-color:var(--accent-dark);border-color:var(--accent-dark);box-shadow:0 4px 12px #3b82f640}button:active{transform:translateY(1px)}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}#root{width:100%;height:100%}.container{min-height:100vh;display:flex;flex-direction:column;align-items:stretch;background-color:var(--bg);padding-top:var(--header-h)}main{flex:1;display:flex;flex-direction:column;align-items:center;padding:3rem 2rem;width:100%;max-width:1400px;margin:0 auto}main h1{text-align:center;margin-bottom:2.5rem;font-size:2em;color:var(--text-primary);width:100%}main h1:after{content:"";display:block;width:40px;height:3px;background:var(--accent);margin:.75rem auto 0;border-radius:2px}header{position:fixed;top:0;left:0;width:100%;height:var(--header-h);display:flex;justify-content:space-between;align-items:center;padding:0 2rem;background:var(--surface);border-bottom:1px solid var(--border);z-index:200;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffeb}header h1{margin:0;font-size:1.1em;font-weight:700;color:var(--text-primary)}.headerName{font-size:.95rem;font-weight:700;color:var(--text-primary);letter-spacing:-.3px;transition:color .2s ease}.headerName:hover{color:var(--accent)}.link{display:flex;align-items:center;gap:2rem}.link a{font-size:.9rem;font-weight:500;color:var(--text-secondary);position:relative;padding:.25rem 0;transition:color .2s ease}.link a:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--accent);transition:width .2s ease}.link a:hover{color:var(--text-primary)}.link a:hover:after{width:100%}.presentation{position:relative;overflow:hidden;background:var(--bg);display:flex;justify-content:center;align-items:center;width:100%;flex:1;min-height:calc(100vh - var(--header-h));padding:4rem 2rem}.heroContent{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:1.4rem;text-align:center;max-width:660px;width:100%}.statusBadge{display:inline-flex;align-items:center;gap:.5rem;background:#f5f3ff;border:1px solid #ddd6fe;color:#7c3aed;padding:.35rem .9rem;border-radius:99px;font-size:.8rem;font-weight:500}.statusDot{width:6px;height:6px;border-radius:50%;background:#22c55e;box-shadow:0 0 6px #22c55e;animation:blink 2.5s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.heroContent h1{font-size:3.2em;margin:0;color:var(--text-primary);letter-spacing:-1.5px;font-weight:800;line-height:1.05}.heroContent h1:after{content:"";display:block;width:44px;height:3px;background:var(--accent);margin:.9rem auto 0;border-radius:2px}.heroBio{font-size:1rem;color:var(--text-secondary);margin:0;line-height:1.75;max-width:520px}.stackBadges{display:flex;flex-wrap:wrap;justify-content:center;gap:.4rem}.stackBadge{font-size:.73rem;font-weight:600;padding:.22rem .62rem;border-radius:6px;background:var(--surface);border:1px solid var(--border);color:var(--text-secondary);font-family:monospace}.socialLinks{display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem}.socialBtn{display:inline-flex;align-items:center;gap:.45rem;padding:.55rem 1.1rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);font-size:.84rem;font-weight:600;transition:all .2s ease}.socialBtn:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.socialBtn--primary{background:var(--accent);border-color:var(--accent);color:#fff}.socialBtn--primary:hover{background:var(--accent-dark);border-color:var(--accent-dark);color:#fff;box-shadow:0 6px 18px #7c3aed59}.discoverLink{display:inline-block;padding:.8rem 2.4rem;background:var(--accent);border:1.5px solid var(--accent);border-radius:var(--radius);color:#fff;font-weight:700;font-size:.95rem;transition:all .2s ease;box-shadow:0 4px 18px #7c3aed59}.discoverLink:hover{background:var(--accent-dark);border-color:var(--accent-dark);color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px #7c3aed80}.pageContent{flex:1;display:flex;flex-direction:column;align-items:center;padding:3rem 2rem;width:100%;max-width:1400px;margin:0 auto}.pageContent h1{text-align:center;margin-bottom:2.5rem;font-size:2em;width:100%}.pageContent h1:after{content:"";display:block;width:40px;height:3px;background:var(--accent);margin:.75rem auto 0;border-radius:2px}.projectPage{display:flex;align-items:flex-start;gap:2rem;width:100%;max-width:1300px}.sideBar{width:240px;flex-shrink:0;position:sticky;top:90px}.sideBarContent{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow-sm)}.sideBarContent h2{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-primary);margin-bottom:1.25rem}.filter h3{font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:1rem}.filterCategory{margin-bottom:1.25rem}.filterCategory h4{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin:0}.filterCategoryToggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;padding:.25rem 0;margin-bottom:.5rem;cursor:pointer;box-shadow:none}.filterCategoryToggle:hover{background:none;box-shadow:none;transform:none}.filterChevron{font-size:1rem;color:var(--text-muted);transform:rotate(90deg);transition:transform .18s ease;line-height:1}.filterChevron--open{transform:rotate(270deg)}.filterCategory ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.35rem}.filterCategory label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary);cursor:pointer;transition:color .15s}.filterCategory label:hover{color:var(--text-primary)}.filterCategory input[type=checkbox]{accent-color:var(--accent);width:14px;height:14px;cursor:pointer}.projectGrid{flex:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;align-items:start}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;display:flex;flex-direction:column;gap:.75rem;box-shadow:var(--shadow-sm);transition:box-shadow .2s ease,transform .2s ease;height:100%}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.card-expanded{grid-column:1 / -1;flex-direction:row;align-items:flex-start;gap:0;transform:none}.card-expanded:hover{transform:none}.cardSummary{display:flex;flex-direction:column;gap:.75rem;flex:1}.card-expanded .cardSummary{flex:0 0 300px;padding-right:1.5rem;border-right:1px solid var(--border)}.card h2{font-size:1.05em;color:var(--text-primary);margin:0}.period{font-size:.78rem;color:var(--text-muted);font-weight:500}.card p{color:var(--text-secondary);font-size:.875rem;line-height:1.6;flex-grow:1}.tags{display:flex;flex-wrap:wrap;gap:.4rem}.tag{font-size:.75rem;font-weight:600;padding:.25rem .65rem;border-radius:99px}.tag-language{background:#f5f3ff;color:#7c3aed;border:1px solid #ddd6fe}.tag-framework{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.tag-tool{background:#fff7ed;color:#c2410c;border:1px solid #fed7aa}.projectLink{font-size:.85rem;font-weight:600;color:var(--accent);border:1.5px solid var(--border);border-radius:var(--radius);padding:.5rem 1rem;text-align:center;transition:all .2s ease;display:inline-block}.projectLink:hover{background:var(--accent);border-color:var(--accent);color:#fff}.card button{width:100%;font-size:.85rem;padding:.5rem 1rem;background:transparent;color:var(--accent);border:1.5px solid var(--border);border-radius:var(--radius);font-weight:600;transition:all .2s ease}.card button:hover{background:var(--surface-hover);border-color:var(--accent);box-shadow:none;transform:none}.projectDetails{border-top:1px solid var(--border);padding-top:1rem;animation:slideDown .25s ease}.card-expanded .projectDetails{flex:1;border-top:none;padding-top:0;padding-left:1.5rem;margin-top:0;animation:fadeIn .25s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.Details{display:flex;flex-direction:column;gap:1rem}.blockDetail{background:var(--surface-hover);border:1px solid var(--border);border-radius:8px;padding:1.25rem}.blockDetail h3{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin-bottom:.75rem}.detailImage{width:100%;max-height:280px;object-fit:cover;border-radius:var(--radius);border:1px solid var(--border);display:block}.blockDetail--bilan p{color:var(--text-secondary);font-size:.875rem;line-height:1.7;margin:0;font-style:italic}.blockDetail ul{margin:0;padding-left:1.25rem}.blockDetail li{color:var(--text-secondary);font-size:.875rem;margin-bottom:.25rem}.acTags{display:flex;flex-wrap:wrap;gap:.4rem}.tag-ac{font-size:.72rem;font-weight:700;padding:.2rem .55rem;border-radius:99px;font-family:monospace;cursor:default}.tag-ac--comp1{background:#eef2ff;color:#4338ca;border:1px solid #c7d2fe}.tag-ac--comp2{background:#faf5ff;color:#7e22ce;border:1px solid #e9d5ff}.tag-ac--comp3{background:#fff7ed;color:#c2410c;border:1px solid #fed7aa}.tag-ac--comp4{background:#ecfdf5;color:#059669;border:1px solid #a7f3d0}.tag-ac--comp5{background:#fefce8;color:#ca8a04;border:1px solid #fde68a}.tag-ac--comp6{background:#fdf2f8;color:#be185d;border:1px solid #fbcfe8}.skillsContainer{display:flex;flex-direction:column;gap:1.25rem;width:100%;max-width:700px;margin:0 auto}.skillCard{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow-sm)}.skillCard h2{font-size:1rem;color:var(--text-primary);margin-bottom:1rem}.listSkill ul{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.5rem}.listSkill li{background:#f5f3ff;border:1px solid #ddd6fe;color:#7c3aed;padding:.3rem .8rem;border-radius:99px;font-size:.8em;font-weight:600}@media(max-width:900px){.projectPage{flex-direction:column}.sideBar{width:100%;position:static}.sideBarContent{display:flex;flex-wrap:wrap;gap:1rem}.filterCategory{margin-bottom:0}}@media(max-width:768px){header{flex-direction:column;gap:.75rem;padding:1rem}.link{gap:1.25rem}main{padding:2rem 1rem}.presentation h1{font-size:2.2em}.projectGrid{grid-template-columns:1fr}}@media(max-width:480px){.presentation h1{font-size:1.8em}.card{padding:1.25rem}}.semesterFilter{display:flex;gap:.5rem;margin-bottom:2rem}.semesterBtn{padding:.5rem 1.25rem;border-radius:99px;border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .18s ease}.semesterBtn:hover{border-color:var(--accent);color:var(--accent)}.semesterBtn--active{background:var(--accent);border-color:var(--accent);color:#fff}.competenceGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.25rem;width:100%}.skillCard{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.85rem;box-shadow:var(--shadow-sm);transition:box-shadow .18s ease,transform .18s ease,opacity .18s ease}.skillCard:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.skillCard[role=button]{cursor:pointer}.skillCard[role=button]:active{transform:scale(.97);opacity:.75;transition:transform .08s ease,opacity .08s ease}.skillCard--open{border-color:var(--accent)}.skillRelated{display:flex;flex-wrap:wrap;gap:.4rem;padding-top:.5rem;border-top:1px solid var(--border);animation:slideDown .2s ease}.skillRelatedPill{font-size:.75rem;font-weight:500;padding:.2rem .6rem;border-radius:6px;background:var(--surface-hover);border:1px solid var(--border);color:var(--text-secondary);transition:all .15s ease}.skillRelatedPill:hover{border-color:var(--accent);color:var(--accent);background:#f5f3ff}.skillCard--active{box-shadow:0 0 0 2px var(--accent),var(--shadow-md);transform:translateY(-2px)}.skillCard--dimmed{opacity:.38}.competenceHeaderTitle{display:flex;align-items:flex-start;gap:.65rem}.compDot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:.35rem}.competenceHeader{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.competenceHeader h2,.competenceHeader h3{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0 0 .2rem}.competenceDesc{font-size:.8rem;color:var(--text-muted);margin:0}.levelBar{width:100%;height:5px;background:var(--border);border-radius:99px;overflow:hidden}.levelBarFill{height:100%;border-radius:99px;transition:width .4s ease}.levelLabel{font-size:.75rem;font-weight:700;flex-shrink:0;align-self:flex-start;margin-top:.1rem}.competenceEmpty{font-size:.82rem;color:var(--text-muted);font-style:italic;margin:0}.competenceProjects{display:flex;flex-direction:column;gap:.5rem;padding-top:.75rem;border-top:1px solid var(--border)}.competenceProjectsLabel{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.projectPills{display:flex;flex-wrap:wrap;gap:.35rem}.projectPill{font-size:.75rem;font-weight:500;padding:.2rem .6rem;border-radius:6px;background:var(--surface-hover);border:1px solid var(--border);color:var(--text-secondary);transition:all .15s ease}.projectPill:hover{border-color:var(--accent);color:var(--accent);background:#f5f3ff}.competenceMain{flex:1;display:flex;flex-direction:column;gap:2.5rem;min-width:0}.compSection{display:flex;flex-direction:column;gap:1rem}.compSectionTitle{font-size:1.1rem;font-weight:700;color:var(--text-primary);padding-bottom:.6rem;border-bottom:2px solid var(--border);margin:0}.skillCloud{display:flex;flex-wrap:wrap;gap:.6rem}.skillChip{display:inline-flex;align-items:center;gap:.45rem;padding:.4rem .9rem;border-radius:99px;font-size:.82rem;font-weight:600;border:1px solid transparent}.skillChip--lang{background:#f5f3ff;color:#7c3aed;border-color:#ddd6fe}.skillChip--fw{background:#f0fdf4;color:#15803d;border-color:#bbf7d0}.skillChip--tool{background:#fff7ed;color:#c2410c;border-color:#fed7aa}.skillChipCount{font-size:.73rem;font-weight:700;opacity:.65;font-family:monospace}.filterSub{display:block;font-size:.72rem;color:var(--text-muted);font-weight:400;margin-top:.05rem}.compSectionTitle{display:flex;align-items:center;gap:1rem}.slicerReset{font-size:.73rem;font-weight:600;color:var(--accent);background:#f5f3ff;border:1px solid #ddd6fe;border-radius:99px;padding:.2rem .7rem;cursor:pointer;transition:all .15s ease;margin-left:auto}.slicerReset:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
