:root{--nav-bg: color-mix(in srgb, var(--bg) 80%, #000 20%);--nav-stroke: color-mix(in srgb, var(--panel) 70%, #fff 5%);--nav-input-stroke: color-mix(in srgb, var(--panel) 70%, #fff 6%);--nav-focus-ring: color-mix( in srgb, var(--accent-strong) 30%, transparent 70% );--nav-focus-border: color-mix(in srgb, var(--accent-strong) 60%, #fff 0%);--nav-hover-underline: color-mix(in srgb, var(--accent-strong) 30%, #fff 10%);--nav-chip: color-mix(in srgb, var(--panel) 85%, #fff 5%);--ring: 0 0 0 3px var(--nav-focus-ring)}.hh-header{position:sticky;top:0;z-index:50;-webkit-backdrop-filter:saturate(120%) blur(8px);backdrop-filter:saturate(120%) blur(8px);background:var(--nav-bg);border-bottom:1px solid var(--nav-stroke)}.nav-container{width:100%;padding:12px 20px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px}.logo-img{height:38px;width:auto;display:block}.nav-left{justify-self:start}.nav-center{display:flex;justify-content:center;gap:28px;font-size:18px;line-height:1}.nav-center a{position:relative;color:var(--text);opacity:.9;text-decoration:none;padding:8px 2px;transition:opacity .18s ease}.nav-center a:after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;transform:scaleX(0);transform-origin:center;background:linear-gradient(90deg,transparent 0 10%,var(--nav-hover-underline) 30% 70%,transparent 90% 100%);transition:transform .22s ease}.nav-center a:hover{opacity:1}.nav-center a:hover:after{transform:scaleX(1)}.nav-right{display:flex;justify-content:flex-end;align-items:center;gap:12px}.search{--icon-size: 16px;--icon-left: 12px;position:relative;display:flex;align-items:center;isolation:isolate}.search input{height:38px;width:210px;max-width:42vw;padding:10px 36px 10px calc(var(--icon-left) + var(--icon-size) + 10px);border-radius:12px;border:1px solid var(--nav-input-stroke);background:var(--panel);color:var(--text);outline:none;transition:width .25s ease,box-shadow .15s ease,border-color .15s ease,background .15s ease}.search input::placeholder{color:var(--muted)}.search:has(input:focus) input{width:clamp(260px,28vw,420px);border-color:var(--nav-focus-border);box-shadow:var(--ring)}.icon-search{position:absolute;left:var(--icon-left);top:50%;transform:translateY(-50%);font-size:var(--icon-size);line-height:1;color:var(--muted);opacity:.58;pointer-events:none;transition:transform .25s ease,color .25s ease,opacity .25s ease}.search:has(input:focus) .icon-search{transform:translateY(-50%) scale(1.1);color:var(--accent-strong);opacity:.82}.search .btn-clear{position:absolute;right:8px;width:24px;height:24px;border:none;border-radius:8px;background:transparent;color:var(--muted);display:grid;place-items:center;cursor:pointer;opacity:0;transform:translateY(1px);transition:opacity .15s ease}.search.has-value .btn-clear{opacity:.9}.search .btn-clear:hover{background:var(--nav-chip);color:var(--text)}.kbd{position:absolute;right:8px;padding:2px 6px;font:500 11px/1.4 ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--muted);background:var(--nav-chip);border:1px solid var(--nav-input-stroke);border-bottom-width:2px;border-radius:6px;opacity:.85;pointer-events:none}.search-panel{position:absolute;top:calc(100% + 8px);left:0;right:0;background:color-mix(in srgb,var(--bg) 70%,#000 30%);border:1px solid var(--nav-stroke);border-radius:14px;-webkit-backdrop-filter:blur(10px) saturate(120%);backdrop-filter:blur(10px) saturate(120%);box-shadow:0 12px 36px #00000059;overflow:hidden}.search-list{max-height:42vh;overflow:auto;scrollbar-width:thin}.search-item{display:flex;align-items:center;gap:10px;padding:10px 12px;color:var(--text);text-decoration:none;border-bottom:1px solid color-mix(in srgb,var(--nav-stroke) 80%,transparent 20%)}.search-item:last-child{border-bottom:0}.search-item:hover{background:color-mix(in srgb,var(--accent-strong) 10%,transparent 90%)}.search-empty{padding:12px;color:var(--muted2);font-size:14px}.admin-link{--size: 38px;width:var(--size);height:var(--size);border-radius:12px;display:grid;place-items:center;color:var(--text);background:color-mix(in srgb,var(--panel) 92%,#fff 2%);border:1px solid var(--nav-input-stroke);box-shadow:0 4px 14px #0000002e;transition:transform .12s ease,box-shadow .12s ease,background .2s ease,border-color .2s ease;text-decoration:none}.admin-link svg{width:20px;height:20px}.admin-link:hover{transform:translateY(-1px);background:color-mix(in srgb,var(--panel) 86%,#fff 6%);border-color:var(--nav-focus-border);box-shadow:0 10px 24px #00000047,var(--ring)}.admin-link:focus-visible{box-shadow:var(--ring);outline:none}@media(max-width:960px){.nav-center{gap:18px;font-size:16px}.search:has(input:focus) input{width:clamp(220px,42vw,340px)}}@media(max-width:680px){.nav-container{grid-template-columns:auto 1fr auto}.nav-center{display:none}.logo-img{height:34px}}@media(prefers-reduced-motion:reduce){.nav-center a:after{transition:none}.search input,.admin-link{transition:none}}:root{--acceuil-bg: var(--bg);--acceuil-text: var(--text);--acceuil-muted: var(--muted);--acceuil-accent: var(--accent-strong)}.acceuil{position:relative;min-height:90vh;padding:0 20px;background:var(--acceuil-bg);color:var(--acceuil-text);display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center}.acceuil-content{flex:1;display:flex;flex-direction:column;justify-content:center;max-width:900px;margin:0 auto}.acceuil-title{font-size:clamp(2.2rem,5vw,3.8rem);font-weight:700;margin-bottom:24px;color:var(--acceuil-accent);letter-spacing:1px}.acceuil-subtitle{font-size:1.1rem;line-height:1.7;color:var(--acceuil-muted);margin-bottom:0}.acceuil-subtitle span{color:var(--acceuil-accent);font-weight:600}.acceuil-bottom{margin-bottom:50px;align-self:stretch}.acceuil-tagline{width:100%;display:block;text-align:center;margin:0 auto 12px}.scroll-down{display:inline-block;color:var(--acceuil-muted);animation:bounce 1.5s infinite;transition:color .3s;position:static;transform:none;margin:0 auto}.scroll-down:hover{color:var(--acceuil-accent)}.scroll-down svg{width:36px;height:36px}:root{--about-bg: #1a1038;--about-accent: #9b5cf6;--about-text: #ffffff;--about-muted: rgba(255, 255, 255, .8);--about-chip-bg: rgba(155, 92, 246, .12);--about-chip-border: rgba(155, 92, 246, .35);--about-border: rgba(255, 255, 255, .12);--about-shadow: 0 8px 24px rgba(0, 0, 0, .25);--about-shadow-hover: 0 12px 28px rgba(0, 0, 0, .35)}.about{position:relative;background:#1a1038;color:var(--about-text);padding:60px 20px 70px;text-align:center;margin-top:20px;font-size:1.3rem;overflow-x:clip;overflow-y:visible;z-index:0;box-shadow:inset 0 6px 16px #00000059,inset 0 -6px 16px #00000059}.about:before,.about:after{content:"";position:absolute;left:0;width:100%;height:80px;pointer-events:none;z-index:1}.about:before{top:0;background:linear-gradient(to bottom,#0b0b14,#0b0b14bf 25%,#1a103873 60%,#1a103800)}.about:after{bottom:0;background:linear-gradient(to top,#0b0b14,#0b0b14bf 25%,#1a103873 60%,#1a103800)}@media(max-width:560px){.about:before,.about:after{height:80px}}.about-container{max-width:1100px;margin:0 auto;padding-inline:24px}.about-title{position:relative;color:var(--about-accent);margin:0 0 20px;font-size:clamp(28px,4vw,40px);letter-spacing:.4px;text-shadow:0 1px 0 rgba(0,0,0,.35),0 6px 22px rgba(155,92,246,.35)}.about-title:after{content:"";position:absolute;left:50%;transform:translate(-50%);top:-22px;width:min(520px,80vw);height:120px;background:radial-gradient(55% 55% at 50% 50%,#9b5cf638,#9b5cf600 60%);filter:blur(14px);z-index:-1}.about-intro{max-width:900px;margin:0 auto 28px;font-size:1.05rem;line-height:1.7;opacity:.92}.goal{font-weight:800}.pill{background:var(--about-chip-bg);border:1px solid var(--about-chip-border);padding:2px 8px;border-radius:999px;font-style:normal}.about-columns{display:grid;grid-template-columns:1fr 1fr;gap:28px 48px;align-items:start;margin:50px auto 34px;max-width:1000px;text-align:left}.about-columns h3{font-size:clamp(20px,2.5vw,26px);margin:0 0 10px}.about-columns p,.about-values li{font-size:1rem;line-height:1.7;opacity:.95}.about-values ul{padding-left:1.1em;display:grid;gap:8px}.about-values li::marker{color:var(--about-accent)}.about-stats{margin:40px auto 12px;display:grid;grid-template-columns:repeat(4,minmax(220px,1fr));gap:18px;justify-items:center}.stat-card{background:#0d0620;border:1px solid var(--about-border);border-radius:18px;padding:22px 26px;width:100%;max-width:260px;height:200px;display:grid;grid-template-rows:auto 1fr auto;align-items:center;justify-items:center;text-align:center;gap:8px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;box-shadow:var(--about-shadow)}.stat-card:hover{transform:translateY(-4px);border-color:#9b5cf673;box-shadow:var(--about-shadow-hover);cursor:pointer}.stat-icon svg{width:44px;height:44px;display:block;filter:drop-shadow(0 4px 10px rgba(155,92,246,.35))}.stat-number{margin:0;font-size:1.4rem;font-weight:800;align-self:center}.stat-label{margin:0;opacity:.88}.scroll-zone{margin-top:40px;display:flex;flex-direction:column;align-items:center;justify-content:center}.scroll-text{color:var(--about-muted);font-size:1rem;font-style:italic;margin-bottom:6px}.scroll-about{display:flex;justify-content:center;align-items:center;color:var(--about-accent);opacity:.85;transition:transform .3s ease,opacity .3s ease;animation:bounce 2s infinite}a:focus-visible{outline:2px solid var(--accent-focus);outline-offset:3px;border-radius:6px}@media(max-width:1024px){.about-stats{grid-template-columns:repeat(2,minmax(220px,1fr))}}@media(max-width:820px){.about-columns{grid-template-columns:1fr;gap:22px;text-align:center}}@media(max-width:560px){.about-stats{grid-template-columns:1fr}.stat-card{max-width:none}}@media(prefers-reduced-motion:reduce){.scroll-about,.stat-card{animation:none!important;transition:none!important}}@keyframes fade-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}@keyframes fade-left{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:none}}@keyframes fade-right{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:none}}@keyframes fade-scale{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:1}}.reveal,.reveal-left,.reveal-right,.reveal-scale{animation:fade-up linear both;animation-timeline:view();animation-range:entry 20% cover 30%}.reveal-left{animation-name:fade-left}.reveal-right{animation-name:fade-right}.reveal-scale{animation-name:fade-scale}@supports not (animation-timeline: view()){.reveal,.reveal-left,.reveal-right,.reveal-scale{opacity:1!important;transform:none!important;animation:none!important}}.about-columns .reveal-left{animation-delay:.06s}.about-columns .reveal-right{animation-delay:.16s}@supports not (animation-timeline: view()){.about-columns .reveal-left,.about-columns .reveal-right{animation-delay:0s}}:root{--bg-card: #1a1038;--bg-chip: #0d0620;--border: rgba(255, 255, 255, .14);--text: #ffffff;--muted: rgba(255, 255, 255, .8);--muted2: rgba(255, 255, 255, .65);--accent: #9b5cf6;--shadow: 0 8px 24px rgba(0, 0, 0, .28)}*,*:before,*:after{box-sizing:border-box}.profils{padding:60px 20px 48px;text-align:center;position:relative;color:var(--text)}.profils-title{position:relative;font-size:clamp(28px,4vw,40px);margin:0 0 28px;color:var(--accent);letter-spacing:.4px;text-shadow:0 1px 0 rgba(0,0,0,.35),0 6px 22px rgba(155,92,246,.35)}.profils-title:after{content:"";position:absolute;left:50%;transform:translate(-50%);top:-22px;width:min(520px,80vw);height:120px;background:radial-gradient(55% 55% at 50% 50%,#9b5cf638,#9b5cf600 60%);filter:blur(14px);z-index:-1}.profils-cartes{display:none}.carte{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;width:100%;max-width:320px;min-height:520px;box-shadow:var(--shadow);transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease;display:grid;grid-template-rows:auto auto auto 1fr auto;row-gap:14px;padding:24px 24px 18px;text-align:center;overflow:visible}.carte:hover{transform:translateY(-4px);box-shadow:0 14px 30px #00000061;border-color:#9b5cf673}.carte-photo{display:grid;place-items:center;margin-bottom:4px;overflow:visible}.carte-photo img{width:120px;height:120px;border-radius:50%;object-fit:cover;border:1px solid var(--border);display:block}.carte-prenom{margin:0;font-size:1.05rem;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profil-nom{margin:0 0 6px;font-size:1.1rem;letter-spacing:.4px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profil-description{margin:2px 0 10px;color:var(--muted);font-size:.95rem;line-height:1.55;display:-webkit-box;-webkit-line-clamp:4;line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;text-align:left;min-height:6.2em}.skills{margin-top:6px}.skills-title{margin:0 0 8px;font-weight:800;color:var(--text)}.skills-list{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;min-height:34px}.skill-tag{background:var(--bg-chip);color:var(--text);font-size:.8rem;border:1px solid var(--border);border-radius:999px;padding:5px 10px}.skill-tag[title="N/A"],.skill-tag:where(:empty){opacity:.7}.profile-divider{width:82%;border:none;border-top:1px solid var(--border);margin:10px auto 8px}.profil-icons{display:flex;justify-content:center;align-items:center;gap:18px;margin-top:8px;margin-bottom:10px}.profil-icons a{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;color:var(--text);text-decoration:none;transition:transform .18s ease,color .18s ease,background-color .18s ease}.profil-icons a:hover{transform:translateY(-2px);color:var(--accent);background:#9b5cf614}.profil-more{margin-top:auto;display:flex;justify-content:center}.profil-more-link{display:flex;align-items:center;justify-content:space-between;gap:10px;width:80%;max-width:240px;padding:10px 16px;background:var(--bg-chip);border:1px solid var(--border);border-radius:20px;color:var(--muted2);font-size:.95rem;text-decoration:none;transition:all .25s ease;box-shadow:0 4px 12px #00000040}.profil-more-link:hover{color:var(--accent);border-color:#9b5cf673;background:#9b5cf614;transform:translateY(-2px);box-shadow:0 6px 18px #00000059}.profil-more-link svg{width:20px;height:20px;stroke-width:1.7;flex-shrink:0}.scroll-zone{margin-top:60px;margin-bottom:40px;display:flex;flex-direction:column;align-items:center;justify-content:center}.scroll-about{display:flex;justify-content:center;align-items:center;color:#9b5cf6;opacity:.85;transition:transform .3s ease,opacity .3s ease;animation:bounce 2s infinite}.carousel-stage{display:flex;justify-content:center;align-items:flex-start;position:relative;height:600px;overflow:visible;margin:40px 0 60px;perspective:1200px;padding-top:20px}.carousel-item{transform-style:preserve-3d;will-change:transform,opacity;overflow:visible}.carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);width:38px;height:38px;border-radius:999px;border:1px solid var(--border);background:var(--bg-chip);color:var(--text);display:grid;place-items:center;font-size:26px;line-height:1;cursor:pointer;box-shadow:var(--shadow);transition:transform .18s ease,background-color .18s ease,color .18s ease,border-color .18s ease;z-index:6}.carousel-arrow:hover{transform:translateY(-50%) scale(1.08);color:var(--accent);background:#9b5cf614;border-color:#9b5cf673}.carousel-arrow.prev{left:30px}.carousel-arrow.next{right:30px}@media(max-width:1024px){.carousel-stage{height:560px}.carousel-arrow.prev{left:10px}.carousel-arrow.next{right:10px}}@media(max-width:760px){.carousel-stage{height:540px}.carousel-arrow.prev{left:5px}.carousel-arrow.next{right:5px}}@media(max-width:560px){.carousel-stage{height:520px}.carousel-arrow{width:34px;height:34px;font-size:22px}.carousel-arrow.prev{left:0}.carousel-arrow.next{right:0}}.projet{position:relative;background:var(--bg-deep);color:var(--ink);padding:60px 20px 70px;text-align:center;margin-top:20px;font-size:1.3rem;overflow-x:clip;overflow-y:visible;z-index:0;box-shadow:inset 0 6px 16px #00000059,inset 0 -6px 16px #00000059}.projet:before,.projet:after{content:"";position:absolute;left:0;width:100%;height:80px;pointer-events:none;z-index:1}.projet:before{top:0;background:linear-gradient(to bottom,var(--bg) 0%,rgba(11,11,20,.75) 25%,rgba(26,16,56,.45) 60%,rgba(26,16,56,0) 100%)}.projet:after{bottom:0;background:linear-gradient(to top,var(--bg) 0%,rgba(11,11,20,.75) 25%,rgba(26,16,56,.45) 60%,rgba(26,16,56,0) 100%)}.projet-title{color:var(--accent);margin:0 0 20px;line-height:1.2}.projet-intro{color:var(--muted);font-size:1rem;max-width:760px;margin:0 auto 16px}.divider{width:100%;border:0;border-top:2px solid var(--border);margin:20px 0}.projets-filtres{display:flex;justify-content:space-between;align-items:center;flex-wrap:nowrap;gap:12px 16px;margin-bottom:15px;padding:12px 16px;border:1px solid var(--border-strong);border-radius:14px;background:#15152759;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:var(--shadow-sm)}.filtres-left{display:flex;flex-wrap:wrap;align-items:center;gap:10px;flex:1}.filtres-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.filtre-check{position:absolute;width:1px;height:1px;margin:-1px;padding:0;border:0;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%)}.filtre-chip{--chip-color: var(--ink);--chip-border: var(--border);--chip-bg: var(--panel);display:inline-flex;align-items:center;gap:8px;border:1px solid var(--chip-border);border-radius:999px;padding:8px 14px;font-size:.9rem;color:var(--chip-color);background:var(--chip-bg);cursor:pointer;transition:background .2s ease,transform .2s ease,border-color .2s ease,color .2s ease,box-shadow .2s ease;line-height:1;-webkit-user-select:none;user-select:none}.filtre-chip:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.filtre-check:focus-visible+.filtre-chip{outline:2px solid var(--accent-focus);outline-offset:2px}.filtre-chip.web{--chip-color: var(--c-web);--chip-border: var(--c-web);--chip-bg: var(--c-web-bg)}.filtre-chip.osint{--chip-color: var(--c-osint);--chip-border: var(--c-osint);--chip-bg: var(--c-osint-bg)}.filtre-chip.pentest{--chip-color: var(--c-pentest);--chip-border: var(--c-pentest);--chip-bg: var(--c-pentest-bg)}.filtre-chip.devsecops{--chip-color: var(--c-devsecops);--chip-border: var(--c-devsecops);--chip-bg: var(--c-devsecops-bg)}.filtre-chip.python{--chip-color: var(--c-python);--chip-border: var(--c-python);--chip-bg: var(--c-python-bg)}.filtre-chip.culture-cyber{--chip-color: var(--c-culture-cyber);--chip-border: var(--c-culture-cyber);--chip-bg: var(--c-culture-cyber-bg)}.filtre-chip.sécurité-isr{--chip-color: var(--c-sécurité-isr);--chip-border: var(--c-sécurité-isr);--chip-bg: var(--c-sécurité-isr-bg)}.filtre-chip.reverse-engineering{--chip-color: var(--c-reverse-engineering);--chip-border: var(--c-reverse-engineering);--chip-bg: var(--c-reverse-engineering-bg)}.filtre-chip.annee-1{--chip-color: #1fb6ff;--chip-border: rgba(31, 182, 255, .6);--chip-bg: rgba(31, 182, 255, .12)}.filtre-chip.annee-2{--chip-color: #7c3aed;--chip-border: rgba(124, 58, 237, .6);--chip-bg: rgba(124, 58, 237, .12)}.filtre-check:checked+.filtre-chip.web{background:var(--c-web);color:#0d0620}.filtre-check:checked+.filtre-chip.osint{background:var(--c-osint);color:#0d0620}.filtre-check:checked+.filtre-chip.pentest{background:var(--c-pentest);color:#fff;box-shadow:0 6px 18px #ef444459}.filtre-check:checked+.filtre-chip.devsecops{background:var(--c-devsecops);color:#fff}.filtre-check:checked+.filtre-chip.python{background:var(--c-python);color:#0d0620}.filtre-check:checked+.filtre-chip.culture-cyber{background:var(--c-culture-cyber);color:#fff;box-shadow:0 6px 18px #f9731659}.filtre-check:checked+.filtre-chip.sécurité-isr{background:var(--c-sécurité-isr);color:#fff}.filtre-check:checked+.filtre-chip.reverse-engineering{background:var(--c-reverse-engineering);color:#fff;box-shadow:0 6px 18px #8b5cf659}.filtre-check:checked+.filtre-chip:after{content:"✕";font-size:.9em;opacity:.9}.filtre-check:checked+.filtre-chip.annee-1{background:linear-gradient(135deg,#1fb6ff,#00b4d8);color:#fff;border-color:#1fb6ffcc;box-shadow:0 0 10px #1fb6ff4d}.filtre-check:checked+.filtre-chip.annee-2{background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;border-color:#7c3aedcc;box-shadow:0 0 10px #7c3aed4d}.filtres-advanced{position:relative;display:inline-block}.filtres-advanced>summary{list-style:none;cursor:pointer;border:1px solid var(--border);border-radius:10px;padding:8px 12px;font-size:.9rem;background:var(--panel);color:var(--ink);transition:background .2s ease,border-color .2s ease,transform .2s ease}.filtres-advanced>summary::-webkit-details-marker{display:none}.filtres-advanced>summary:hover{background:#ffffff0a;border-color:var(--accent-focus);transform:translateY(-1px)}.filtres-advanced[open]>summary{border-bottom-left-radius:0;border-bottom-right-radius:0}.filtres-advanced-panel{position:absolute;right:0;margin-top:6px;min-width:260px;padding:12px;border:1px solid var(--border-strong);border-top:0;border-bottom-left-radius:12px;border-bottom-right-radius:12px;background:#0d0620f5;box-shadow:var(--shadow-md);z-index:10;display:grid;gap:10px}.filtres-advanced-panel .filtre-check+.filtre-chip{width:100%;justify-content:space-between}.projets-carousel{position:relative;margin-top:32px}.projets-cartes{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:var(--gap);justify-items:start;align-items:stretch;opacity:1;transform:translateY(0);transition:opacity .26s ease,transform .26s ease;perspective:1000px}.projets-cartes.is-transitioning{opacity:.3;transform:translateY(6px)}.projet-carte{position:relative;background:var(--panel-deep);border:1px solid var(--border-strong);border-radius:var(--radius-lg);padding:22px;width:100%;max-width:560px;min-height:210px;color:var(--ink);display:flex;flex-direction:column;gap:16px;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;box-shadow:0 4px 10px #00000059,0 1px 3px #ffffff0a inset}.projet-carte:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 12px 26px #00000073,0 4px 12px #8b5cf64d;border-color:#b79cff73}.projet-titre{font-size:1.2rem;font-weight:700;text-align:left;margin:0 130px 0 0}.projet-annee{position:absolute;top:22px;right:22px;font-size:.78rem;font-weight:600;padding:.35rem 1.1rem;border-radius:999px;color:#fff;letter-spacing:.03em;text-transform:uppercase;opacity:.95;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:all .25s ease}.projet-annee.annee-1{background:linear-gradient(135deg,#1fb6ff,#00b4d8);box-shadow:0 0 6px #1fb6ff40}.projet-annee.annee-2{background:linear-gradient(135deg,#7c3aed,#a855f7);box-shadow:0 0 6px #7c3aed40}.projet-annee:hover{transform:translateY(-1px);filter:brightness(1.12);box-shadow:0 0 10px #8b5cf64d;opacity:1}.projet-desc{font-size:1rem;color:var(--muted);line-height:1.5;text-align:left;margin:3px 0 0;flex-grow:1}.projet-footer{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-top:auto}.projet-tags{display:flex;flex-wrap:wrap;gap:8px}.tag{border:1px solid var(--border-soft);border-radius:999px;padding:6px 12px;font-size:.85rem;color:var(--ink);background:#ffffff05}.tag--web{color:var(--c-web);border-color:var(--c-web);background:var(--c-web-bg)}.tag--osint{color:var(--c-osint);border-color:var(--c-osint);background:var(--c-osint-bg)}.tag--pentest{color:var(--c-pentest);border-color:var(--c-pentest);background:var(--c-pentest-bg)}.tag--devsecops{color:var(--c-devsecops);border-color:var(--c-devsecops);background:var(--c-devsecops-bg)}.tag--python{color:var(--c-python);border-color:var(--c-python);background:var(--c-python-bg)}.tag--culture-cyber{color:var(--c-culture-cyber);border-color:var(--c-culture-cyber);background:var(--c-culture-cyber-bg)}.tag--sécurité-isr{color:var(--c-sécurité-isr);border-color:var(--c-sécurité-isr);background:var(--c-sécurité-isr-bg)}.tag--reverse-engineering{color:var(--c-reverse-engineering);border-color:var(--c-reverse-engineering);background:var(--c-reverse-engineering-bg)}.projet-link{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background:#ffffff0a;border:1px solid rgba(255,255,255,.12);border-radius:20px;color:var(--muted);font-size:.9rem;text-decoration:none;transition:all .25s ease;box-shadow:0 4px 10px #00000040;white-space:nowrap}.projet-link:hover{color:var(--accent);border-color:#9b5cf673;background:#9b5cf614;transform:translateY(-2px);box-shadow:0 6px 18px #00000059,0 0 8px #9b5cf640}.carousel-nav{display:flex;justify-content:center;align-items:center;gap:14px;margin-top:26px;-webkit-user-select:none;user-select:none}.carousel-btn{--nav-size: 42px;width:var(--nav-size);height:var(--nav-size);display:inline-flex;align-items:center;justify-content:center;background:var(--panel);border:1px solid var(--border-strong);border-radius:12px;color:var(--ink);cursor:pointer;box-shadow:0 6px 16px #00000059;transition:background .2s ease,transform .2s ease,opacity .2s ease}.carousel-btn:hover{background:var(--accent);transform:translateY(-2px)}.carousel-btn[disabled]{opacity:.35;cursor:not-allowed;transform:none}.carousel-btn svg{width:20px;height:20px}.carousel-dots{display:inline-flex;align-items:center;gap:10px}.carousel-dot{width:10px;height:10px;border-radius:50%;border:2px solid var(--border);background:transparent;padding:0;cursor:pointer;transition:transform .15s ease,background .15s ease,border-color .15s ease}.carousel-dot:hover{transform:scale(1.1);border-color:var(--accent-focus)}.carousel-dot[aria-current=true]{background:var(--accent-focus);border-color:var(--accent-focus)}.voir-plus{display:flex;margin:40px auto 6px}.voir-plus a{display:inline-flex;align-items:center;gap:6px;color:var(--ink);font-size:1rem;text-decoration:none;transition:color .2s ease,transform .2s ease}.voir-plus a:hover{color:var(--accent);transform:translate(3px)}.voir-plus svg{width:18px;height:18px}.scroll-zone{margin-top:44px;display:flex;flex-direction:column;align-items:center;justify-content:center}.scroll-text{color:#fffc;font-size:1rem;font-style:italic;margin-bottom:6px}.scroll-about{display:flex;justify-content:center;align-items:center;color:var(--accent);opacity:.85;transition:transform .3s ease,opacity .3s ease;animation:bounce 2s infinite}.scroll-about:hover{opacity:1;transform:translateY(4px)}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(6px)}60%{transform:translateY(3px)}}@media(max-width:1200px){.projets-cartes{grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}}@media(max-width:900px){.projets-cartes{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media(max-width:700px){.projets-filtres{flex-direction:column;align-items:stretch;text-align:center}.filtres-left,.filtres-right{justify-content:center}.filtres-advanced-panel{right:50%;transform:translate(50%);min-width:min(92vw,420px)}.projets-cartes{grid-template-columns:minmax(280px,1fr)}.projet-titre{margin-right:110px}.projet-annee{top:20px;right:16px}}@media(max-width:360px){.projet-carte{padding:16px;border-radius:16px}.projet-titre{margin-right:90px}}:root{--skills-bg: var(--bg);--skills-title: #9b5cf6;--skills-muted: #9aa0b4;--text: #ffffff;--grad-violet: linear-gradient(145deg, #5b1bdb, #a34de0);--grad-rose: linear-gradient(145deg, #e34d71, #d86fa6);--square-size: 80px;--square-radius: 15px}.competences{background:var(--skills-bg);padding:40px 20px 70px;text-align:center;margin-top:20px;font-size:1.3rem}.competences-section{text-align:center;margin-top:40px;margin-bottom:100px;position:relative;overflow:hidden}.competences-title{font-size:2rem;font-weight:700;color:var(--skills-title);margin-bottom:40px}.competences-intro{max-width:600px;margin:0 auto 30px;font-size:1rem;color:var(--skills-muted);line-height:1.5}.competences-container{display:flex;justify-content:center;gap:120px;margin-bottom:2%;flex-wrap:wrap;margin-top:4%}.competences-left{margin-top:0}.competences-right{margin-top:70px}.competences-grid{display:grid;grid-template-columns:repeat(7,70px);grid-template-rows:repeat(4,70px);gap:15px;justify-content:center}.competence-square{position:relative;width:var(--square-size);height:var(--square-size);border-radius:var(--square-radius);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;font-size:.8rem;font-weight:600;color:#fff;background:linear-gradient(145deg,#5b1bdb80,#a34de080);backdrop-filter:blur(10px) saturate(165%);-webkit-backdrop-filter:blur(10px) saturate(165%);border:1px solid rgba(255,255,255,.12);box-shadow:inset 0 0 12px #ffffff0f,0 6px 16px #0000006b;text-shadow:0 1px 3px rgba(0,0,0,.4);animation:gentle-float 7s ease-in-out infinite;will-change:transform,box-shadow;transition:transform .25s ease,box-shadow .25s ease,filter .25s ease,backdrop-filter .25s ease}.competence-square:after{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(165deg,#ffffff1f,#ffffff14 24%,#fff0 50%,#00000029);pointer-events:none;mix-blend-mode:screen}.violet{background:linear-gradient(145deg,#5b1bdb80,#a34de080);border-color:#9b5cf647}.rose{background:linear-gradient(145deg,#e34d7180,#d86fa680);border-color:#e34d7147}.competence-square i{font-size:28px;margin-bottom:6px;opacity:.98;filter:drop-shadow(0 1px 2px rgba(0,0,0,.35))}.empty{background:transparent;box-shadow:none}.competences-grid .competence-square:hover{transform:translateY(-5px) scale(1.02);backdrop-filter:blur(12px) saturate(185%);-webkit-backdrop-filter:blur(12px) saturate(185%);box-shadow:0 14px 28px #00000094,0 0 24px #9b5cf659,inset 0 0 20px #ffffff14;filter:saturate(1.12);cursor:pointer}.violet:hover{background:linear-gradient(145deg,#5b1bdba3,#a34de0a3)}.rose:hover{background:linear-gradient(145deg,#e34d71a3,#d86fa6a3)}@keyframes gentle-float{0%{transform:translateY(0) rotate(.25deg)}20%{transform:translateY(-2.2px) rotate(-.45deg)}50%{transform:translateY(.8px) rotate(.35deg)}80%{transform:translateY(-2.5px) rotate(0)}to{transform:translateY(0) rotate(.25deg)}}.competences-grid .competence-square:nth-child(3n){animation-delay:-.5s;animation-duration:6.8s}.competences-grid .competence-square:nth-child(4n){animation-delay:-1.1s;animation-duration:7.6s}.competences-grid .competence-square:nth-child(5n+2){animation-delay:-1.7s;animation-duration:7.2s}.competences-section .skills-bg{position:absolute;inset:0;z-index:0;pointer-events:none;-webkit-mask:radial-gradient(120% 100% at 50% 30%,#000 60%,transparent 100%);mask:radial-gradient(120% 100% at 50% 30%,#000 60%,transparent 100%)}.competences-section>*:not(.skills-bg){position:relative;z-index:1}.skills-bg .sq-layer{position:absolute;inset:0;transform:translateZ(0)}.skills-bg .layer-back{transform:translateY(-2%)}.skills-bg .layer-mid{transform:translateY(0)}.skills-bg .layer-top{transform:translateY(2%)}.skills-bg .sq{position:absolute;left:var(--x);top:var(--y);width:var(--size);height:var(--size);border-radius:4px;background:var(--sq, #9b5cf6);background-image:linear-gradient(145deg,#ffffff14,#0000001a);background-blend-mode:overlay;opacity:var(--alpha, .35);mix-blend-mode:screen;box-shadow:0 0 8px #9b5cf64d,0 0 18px #9b5cf62e;animation:sq-float var(--dur, 12s) ease-in-out var(--delay, 0s) infinite alternate;transform:translateZ(0) rotate(var(--rot, 0deg));will-change:transform,opacity}@keyframes sq-float{0%{transform:translateZ(0) rotate(var(--rot))}50%{transform:translate3d(var(--tx),var(--ty),0) rotate(calc(var(--rot) * 1.5))}to{transform:translateZ(0) rotate(var(--rot))}}.transition-profil{text-align:center;padding:72px 20px 84px;position:relative;color:var(--text);scroll-margin-top:80px;overflow:visible;background:transparent}.transition-profil:before,.transition-profil:after{content:none!important;display:none!important;background:none!important;filter:none!important}.transition-profil h3{font-size:clamp(1.6rem,1.2rem + 1.2vw,2.1rem);letter-spacing:.2px;line-height:1.15;color:var(--skills-title);margin-bottom:14px}.transition-profil p{max-width:780px;margin:28px auto;line-height:1.7;color:var(--skills-muted)}.btn-profil{display:inline-block;padding:12px 28px;border-radius:12px;border:1px solid rgba(155,92,246,.8);color:#cdb8ff;background:transparent;font-weight:600;text-decoration:none;transition:transform .2s ease,box-shadow .25s ease,background .25s ease,color .25s ease,border-color .25s ease}.btn-profil:hover{background:#9b5cf61f;border-color:#9b5cf6;color:#fff;box-shadow:0 0 22px #9b5cf659,inset 0 0 12px #ffffff0f;transform:translateY(-2px)}.btn-profil:focus-visible{outline:none;box-shadow:0 0 0 3px #9b5cf673,0 0 0 6px #9b5cf62e}@media(max-width:1024px){.competences-container{gap:64px}}@media(max-width:768px){.competences-container{gap:40px}.competences-right{margin-top:30px}.competences-grid{grid-template-columns:repeat(5,64px);grid-template-rows:repeat(5,64px);gap:12px}.skills-bg .sq{opacity:calc(var(--alpha, .35) - .08);filter:saturate(.95)}}@media(max-width:640px){.transition-profil{padding:60px 16px 72px}.btn-profil{width:92%;max-width:360px}}@media(prefers-reduced-motion:reduce){.competences-grid .competence-square,.skills-bg .sq{animation:none}}html{scroll-behavior:smooth}:root{--footer-border: rgba(255, 255, 255, .1);--footer-text: rgba(255, 255, 255, .8)}.footer{text-align:center;padding:15px 0;border-top:1px solid var(--footer-border)}.footer p{color:var(--footer-text);font-size:.85rem;letter-spacing:.5px;margin:0;font-family:monospace;text-align:center}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font-main);scroll-behavior:smooth;overflow-x:hidden}a{color:inherit;text-decoration:none}.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--container-padding)}.glare-heading{position:relative;text-shadow:0 1px 0 rgba(0,0,0,.35),0 6px 22px rgba(155,92,246,.35)}.glare-heading:after{content:"";position:absolute;left:50%;transform:translate(-50%);top:-22px;width:min(520px,80vw);height:120px;background:radial-gradient(55% 55% at 50% 50%,#9b5cf638,#9b5cf600 60%);filter:blur(14px);z-index:-1}:root{--bg: #0b0b14;--panel: #151527;--text: #e8e8f3;--muted: #9aa0b4;--accent: #9b5cf6;--accent-strong: #9b5cf6;--accent-focus: #b79cff;--bg-deep: #1a1038;--panel-deep: #0d0620;--border: rgba(255, 255, 255, .14);--border-strong: rgba(255, 255, 255, .2);--border-soft: rgba(255, 255, 255, .3);--ink: #ffffff;--shadow-sm: 0 4px 12px rgba(0, 0, 0, .3);--shadow-md: 0 8px 24px rgba(0, 0, 0, .28);--shadow-lg: 0 12px 28px rgba(0, 0, 0, .35);--radius-sm: 10px;--radius-md: 18px;--radius-lg: 22px;--gap: 20px;--font-main: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial;--font-mono: monospace;--max-width: 1200px;--container-padding: 16px;--grad-violet: linear-gradient(145deg, #5b1bdb, #a34de0);--grad-rose: linear-gradient(145deg, #e34d71, #d86fa6);--focus-ring: 0 0 0 3px var(--accent-focus);--c-web: #6ee7b7;--c-osint: #f59e0b;--c-pentest: #ef4444;--c-devsecops: #3b82f6;--c-python: #eab308;--c-culture-cyber: #f97316;--c-sécurité-isr: #10b981;--c-reverse-engineering: #8b5cf6;--c-web-bg: rgba(110, 231, 183, .16);--c-osint-bg: rgba(245, 158, 11, .16);--c-pentest-bg: rgba(239, 68, 68, .16);--c-devsecops-bg: rgba(59, 130, 246, .16);--c-python-bg: rgba(234, 179, 8, .16);--c-culture-cyber-bg: rgba(249, 115, 22, .16);--c-sécurité-isr-bg: rgba(16, 185, 129, .16);--c-reverse-engineering-bg: rgba(139, 92, 246, .16)}
