@import"https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Mono:wght@300;400;500&family=Outfit:wght@300;400;500;600&display=swap";:root{--clr-bg: #0d0f10;--clr-surface: #141719;--clr-surface-2: #1c2024;--clr-border: rgba(255, 255, 255, .07);--clr-glow: rgba(100, 220, 200, .12);--clr-accent: #64dcc8;--clr-accent-2: #a78bfa;--clr-danger: #f87171;--clr-text: #e8e4de;--clr-text-muted: #7a8090;--clr-heading: #f0ece5;--clr-subheading: #a0b4c5;--font-display: "DM Serif Display", Georgia, serif;--font-body: "Outfit", sans-serif;--font-mono: "DM Mono", "Courier New", monospace;--space-xs: .5rem;--space-sm: 1rem;--space-md: 2rem;--space-lg: 4rem;--space-xl: 8rem;--max-w: 1100px;--max-w-narrow: 680px;--radius-sm: 8px;--radius-md: 15px;--radius-lg: 15%;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in: cubic-bezier(.7, 0, .84, 0);--duration: .35s;--duration-lg: .65s;--shadow-card: 0 8px 40px rgba(0, 0, 0, .45), 0 1px 0 var(--clr-border) inset;--shadow-glow: 0 0 60px var(--clr-glow)}*,*:before,*:after{margin:0;box-sizing:border-box}html{scroll-behavior:smooth;overscroll-behavior-y:none;font-size:16px}body{font-family:var(--font-body);font-weight:300;line-height:1.7;background-color:var(--clr-bg);color:var(--clr-text)}#app{width:100%;overflow-x:hidden}h1,h2,h3{line-height:1.15;letter-spacing:-.02em}h1{font-family:var(--font-display);font-size:clamp(2.4rem,6vw,5rem);color:var(--clr-heading)}h2{font-family:var(--font-display);font-size:clamp(1.8rem,3.5vw,2.8rem);color:var(--clr-subheading);margin-bottom:var(--space-md)}h3{font-family:var(--font-body);font-size:1.15rem;font-weight:600;color:var(--clr-heading);margin-bottom:var(--space-xs)}p{color:var(--clr-text);margin-bottom:var(--space-sm);font-size:1rem}p.lead{font-size:1.15rem;color:var(--clr-text-muted)}a{color:var(--clr-accent);text-decoration:none;transition:color var(--duration) var(--ease-out)}a:hover{color:var(--clr-text)}.container,.projects-content,.skills-content{width:100%;max-width:var(--max-w);margin-inline:auto;padding-inline:var(--space-md)}.container--narrow{max-width:var(--max-w-narrow);margin-inline:auto;padding-inline:var(--space-md)}section{text-align:center;margin-inline:auto}.header{position:sticky;top:0;z-index:100;background:#0d0f10d1;backdrop-filter:blur(18px) saturate(1.4);-webkit-backdrop-filter:blur(18px) saturate(1.4);border-bottom:1px solid var(--clr-border);padding-block:var(--space-xs)}.nav{display:flex;justify-content:space-between;align-items:center;max-width:var(--max-w);margin-inline:auto;padding-inline:var(--space-md)}.branding h1{font-family:var(--font-mono);font-size:1.05rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;text-shadow:none}.branding h1:before{content:">";margin-right:.4em;opacity:.5;color:var(--clr-accent)}.branding h1 a{font-family:var(--font-mono);font-size:1.05rem;font-weight:500;color:var(--clr-text-muted);letter-spacing:.05em;text-transform:uppercase;text-shadow:none;position:relative;padding-bottom:2px}.branding h1 a:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--clr-accent);transition:width var(--duration) var(--ease-out)}.branding h1 a:hover{color:var(--clr-text)}.branding h1 a:hover:after{width:100%}.nav-links{list-style:none;display:flex;gap:var(--space-md)}.nav-links li a{font-size:.85rem;font-weight:500;font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--clr-text-muted);text-shadow:none;position:relative;padding-bottom:2px}.nav-links li a:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--clr-accent);transition:width var(--duration) var(--ease-out)}.nav-links li a:hover{color:var(--clr-text)}.nav-links li a:hover:after{width:100%}.entete{max-width:fit-content;padding-inline:var(--space-sm)}.entete h1,.entete h1 a,.entete p{color:var(--clr-text);font-size:inherit}.intro{display:flex;align-items:center;gap:var(--space-lg);min-height:90vh;padding-block:var(--space-lg);padding-inline:var(--space-md);max-width:var(--max-w);margin-inline:auto;position:relative;overflow:hidden}.intro:before{content:"";position:absolute;top:-20%;right:-10%;width:700px;height:700px;background:radial-gradient(circle,rgba(100,220,200,.06) 0%,transparent 65%);pointer-events:none}.intro:after{content:"";position:absolute;bottom:-10%;left:5%;width:500px;height:500px;background:radial-gradient(circle,rgba(167,139,250,.05) 0%,transparent 65%);pointer-events:none}.intro-content{flex:1 1 50%;min-width:0;max-width:50%;text-align:left;padding-inline:0;position:relative;z-index:1}.intro-content p{font-size:1.1rem;line-height:1.8;color:var(--clr-text-muted)}.intro-content h1,.intro-content h2{text-shadow:none;margin-bottom:.25em}.intro-content h2{font-family:var(--font-mono);font-size:1rem;color:var(--clr-accent);letter-spacing:.08em;text-transform:uppercase;margin-bottom:var(--space-sm)}.intro-content img{width:64px;height:64px;border-radius:50%;border:2px solid var(--clr-border);margin-bottom:var(--space-sm)}.container-portrait{flex:1 1 50%;min-width:0;max-width:50%;position:relative;right:0}.portrait{border-radius:50%;width:40%}.main-portrait{width:70%;border-radius:var(--radius-lg);display:block;border:1px solid var(--clr-border);box-shadow:var(--shadow-glow),var(--shadow-card);transition:transform var(--duration-lg) var(--ease-out),box-shadow var(--duration-lg) var(--ease-out)}.main-portrait:hover,.portrait:hover{transform:scale(1.025) rotate(-1deg);box-shadow:0 0 80px #64dcc82e,var(--shadow-card)}.biographie,.future{display:flex;align-items:center;padding-block:var(--space-lg)}.project-grid,.skill-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.8rem}.skill-grid{grid-auto-rows:auto}.project-card,.project-image,.skill-card,.error{position:relative;overflow:hidden;border:1px solid var(--clr-border);border-radius:var(--radius-md);padding:var(--space-md);background:var(--clr-surface);transition:transform var(--duration) var(--ease-out),box-shadow var(--duration) var(--ease-out),border-color var(--duration) var(--ease-out);box-shadow:var(--shadow-card)}.project-card:before,.skill-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.025) 0%,transparent 60%);opacity:0;transition:opacity var(--duration) var(--ease-out);pointer-events:none}.project-card:hover,.skill-card:hover,.project-image:hover{transform:translateY(-4px);border-color:#64dcc833;box-shadow:0 20px 60px #00000080,0 0 0 1px #64dcc81a}.project-card:hover:before,.skill-card:hover:before{opacity:1}.project-card{height:320px;padding:0;align-content:unset;background-size:cover;background-position:center;background-color:var(--clr-surface-2);text-align:left;cursor:pointer;display:flex;flex-direction:column;justify-content:flex-end}.project-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius-md);background:linear-gradient(to top,#080a0bf2,#080a0b8c 38%,#080a0b00 70%);transition:background var(--duration) var(--ease-out);pointer-events:none;z-index:0}.project-card:hover:before{background:linear-gradient(to top,#080a0bfa,#080a0bd1 55%,#080a0b2e)}.project-card h3,.project-card p{position:relative;z-index:1;margin:0}.project-card h3{padding:0 var(--space-md) .35rem;font-size:1.35rem;font-weight:600;color:#fff;letter-spacing:-.01em;text-shadow:3px 1px 1px black}.project-card p{padding:0 var(--space-md);font-size:.85rem;line-height:1.5;color:#e8e4dec7;max-height:0;overflow:hidden;opacity:0;transition:max-height .4s var(--ease-out),opacity .3s var(--ease-out),padding .3s var(--ease-out)}.project-card p:last-child{padding-bottom:var(--space-md)}.project-card:hover p{max-height:8rem;opacity:1}.project-image{padding:0;max-height:220px;border-radius:var(--radius-md)}.project-image img{width:100%;height:100%;display:block}.project-links{margin-top:var(--space-sm);display:flex;flex-direction:column;gap:var(--space-xs);flex-wrap:wrap}.project-links a{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--clr-text-muted);border:1px solid var(--clr-border);border-radius:4px;padding:.2em .7em;transition:all var(--duration) var(--ease-out)}.project-links a:hover{color:var(--clr-accent);border-color:var(--clr-accent);background:#64dcc80f}.project-content-image{max-width:70%;margin:0 auto;padding:0 2rem}.archives,.projects,.collaborators-grid,.skills,.contact{padding-block:var(--space-lg)}.skill-card{text-align:center}.skill-card a img,.project-card a img{width:56px;height:56px;object-fit:contain;transition:transform var(--duration) var(--ease-out);filter:grayscale(30%)}.skill-card a img:hover,.project-card a img:hover{transform:scale(1.15);filter:grayscale(0%)}.link-img a img:not(.social-links .link-img a img){max-width:52px;max-height:52px;object-fit:contain}.link-img a img:hover{transform:scale(1.1)}.social-links{display:flex;justify-content:center;gap:var(--space-lg);margin:var(--space-md) 0}.social-links a{display:inline-flex;align-items:center;justify-content:center;transition:transform var(--duration) var(--ease-out),filter var(--duration);filter:grayscale(20%)}.social-links a:hover{transform:translateY(-3px);filter:grayscale(0%)}.social-links div a img,.project-links div a img{max-height:56px}.collaborators-grid{display:flex;justify-content:center;align-items:center;gap:var(--space-md)}.container-portrait{width:40%;margin:0;right:0}.archives{display:flex;flex-direction:column;width:min(30%,280px)}.fieldset-archives{border:1px solid var(--clr-border);border-radius:var(--radius-sm);padding:var(--space-sm)}.fieldset-archives ul li{margin:var(--space-xs) 0;list-style:none;font-family:var(--font-mono);font-size:.9rem}details ul{position:absolute;z-index:10;background:var(--clr-surface-2);border:1px solid var(--clr-border);border-radius:var(--radius-sm);padding:var(--space-xs);list-style:none}.error{margin:10% auto;text-align:center;max-width:400px}.error h1{color:var(--clr-danger);font-family:var(--font-mono);font-size:3rem}footer{width:100%;padding:var(--space-md) var(--space-lg);display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);background:var(--clr-surface);border-top:1px solid var(--clr-border);font-size:.8rem;font-family:var(--font-mono);color:var(--clr-text-muted)}.footer-text ul{list-style:none;display:flex;gap:var(--space-md)}.footer-text ul li{color:var(--clr-text-muted)}.footer-social{display:flex;gap:var(--space-sm);align-items:center}@keyframes fade-up{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.project-card,.skill-card{animation:fade-up .5s var(--ease-out) both}.project-grid .project-card:nth-child(2){animation-delay:.08s}.project-grid .project-card:nth-child(3){animation-delay:.16s}.project-grid .project-card:nth-child(4){animation-delay:.24s}.skill-grid .skill-card:nth-child(2){animation-delay:.06s}.skill-grid .skill-card:nth-child(3){animation-delay:.12s}.skill-grid .skill-card:nth-child(4){animation-delay:.18s}section+section{border-top:1px solid var(--clr-border)}.tag{display:inline-block;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--clr-accent);background:#64dcc814;border:1px solid rgba(100,220,200,.2);border-radius:4px;padding:.15em .6em;margin-bottom:var(--space-sm)}@media screen and (max-width:1080px){.intro{flex-direction:column;min-height:auto;padding-block:var(--space-lg) var(--space-md);padding-inline:var(--space-md);text-align:center;gap:var(--space-md)}.intro-content{max-width:100%;flex:none;width:100%;text-align:center}.intro-content h2{font-size:.9rem}.container-portrait{flex:none;max-width:65%;width:65%;right:0}.biographie,.future{flex-direction:column;padding-block:var(--space-md)}.entete{max-width:100%}.nav{padding-inline:var(--space-sm)}.nav-links{gap:var(--space-sm)}.nav-links li a{font-size:.75rem}.project-grid{grid-template-columns:1fr;grid-auto-rows:300px}.project-card h3{font-size:4rem}.collaborators-grid{flex-direction:column}.collaborators-grid .container-portrait{width:70%}.social-links{gap:var(--space-md)}footer{flex-direction:column;text-align:center;padding:var(--space-md)}.footer-text ul{flex-direction:column;gap:var(--space-xs)}.footer-text{display:block}}@media screen and (max-width:600px){:root{--space-lg: 2.5rem;--space-xl: 4rem}.nav-links{display:none}.container-portrait{max-width:80%;width:80%}h1{font-size:2.2rem}h2{font-size:1.6rem}.intro-content p{font-size:1rem}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation:none!important;transition-duration:.01ms!important}html{scroll-behavior:auto}}.portfolio-apprentissage[data-v-6337017e]{font-family:var(--font-body);color:var(--clr-text)}.pa-hero[data-v-6337017e]{padding-block:var(--space-lg);border-bottom:1px solid var(--clr-border);text-align:left}.pa-hero h1[data-v-6337017e]{font-family:var(--font-display);font-size:clamp(2.2rem,5vw,4rem);color:var(--clr-heading);margin:var(--space-sm) 0 var(--space-md);letter-spacing:-.03em}.pa-hero .lead[data-v-6337017e]{font-size:1.1rem;color:var(--clr-text-muted);max-width:700px;line-height:1.8;margin-bottom:var(--space-md)}.pa-meta[data-v-6337017e]{display:flex;gap:var(--space-md);flex-wrap:wrap;margin-top:var(--space-md)}.pa-meta-item[data-v-6337017e]{display:flex;flex-direction:column;gap:.2rem;padding:var(--space-sm) var(--space-md);background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-sm)}.pa-meta-label[data-v-6337017e]{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--clr-text-muted)}.pa-meta-value[data-v-6337017e]{font-weight:500;color:var(--clr-heading);font-size:.95rem}.pa-intro-block[data-v-6337017e]{padding-block:var(--space-lg);text-align:left}.pa-intro-block p[data-v-6337017e]{color:var(--clr-text-muted);font-size:1.05rem;line-height:1.85}.accent[data-v-6337017e]{color:var(--clr-accent);font-weight:500}.pa-competence[data-v-6337017e]{padding-block:var(--space-lg);border-top:1px solid var(--clr-border);text-align:left}.competence-header[data-v-6337017e]{display:flex;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-md)}.competence-badge[data-v-6337017e]{flex-shrink:0;width:64px;height:64px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:1.4rem;font-weight:500;color:#fff}.competence-header.realiser .competence-badge[data-v-6337017e]{background:#b43c3ccc}.competence-header.collaborer .competence-badge[data-v-6337017e]{background:#1e283ce6;border:1px solid rgba(100,220,200,.2)}.competence-header.conduire .competence-badge[data-v-6337017e]{background:#1e325ae6;border:1px solid rgba(167,139,250,.2)}.competence-header h2[data-v-6337017e]{font-family:var(--font-display);font-size:clamp(1.4rem,2.5vw,2rem);color:var(--clr-heading);margin-bottom:.2em}.competence-desc[data-v-6337017e]{font-size:.9rem;color:var(--clr-text-muted);font-style:italic;margin:0}.ce-strip[data-v-6337017e]{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:var(--space-md)}.ce-item[data-v-6337017e]{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.06em;color:var(--clr-text-muted);border:1px solid var(--clr-border);border-radius:4px;padding:.2em .7em;background:var(--clr-surface)}.ac-grid[data-v-6337017e]{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.6rem}.ac-card[data-v-6337017e]{position:relative;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-md);padding:var(--space-md);box-shadow:var(--shadow-card);transition:transform var(--duration) var(--ease-out),border-color var(--duration) var(--ease-out),box-shadow var(--duration) var(--ease-out);animation:fade-up-6337017e .5s var(--ease-out) both}.ac-card[data-v-6337017e]:hover{transform:translateY(-3px);border-color:#64dcc82e;box-shadow:0 20px 50px #0006,0 0 0 1px #64dcc814}.ac-number[data-v-6337017e]{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--clr-accent);margin-bottom:.4rem}.ac-card h3[data-v-6337017e]{font-size:1rem;font-weight:600;color:var(--clr-heading);margin-bottom:var(--space-sm);line-height:1.35}.ac-card p[data-v-6337017e]{font-size:.9rem;color:var(--clr-text-muted);line-height:1.75;margin-bottom:var(--space-sm)}.ac-status[data-v-6337017e]{display:inline-block;font-family:var(--font-mono);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;padding:.2em .7em;border-radius:4px;margin-bottom:var(--space-sm)}.ac-status.acquired[data-v-6337017e]{color:var(--clr-accent);background:#64dcc814;border:1px solid rgba(100,220,200,.22)}.ac-status.in-progress[data-v-6337017e]{color:var(--clr-accent-2);background:#a78bfa14;border:1px solid rgba(167,139,250,.22)}.traces[data-v-6337017e]{margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--clr-border)}.trace-label[data-v-6337017e]{display:block;font-family:var(--font-mono);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--clr-text-muted);margin-bottom:.5rem}.trace-list[data-v-6337017e]{display:flex;flex-wrap:wrap;gap:.4rem}.trace-item[data-v-6337017e]{font-family:var(--font-mono);font-size:.7rem;color:var(--clr-text-muted);background:var(--clr-surface-2);border:1px solid var(--clr-border);border-radius:4px;padding:.15em .6em}.pa-bilan[data-v-6337017e]{padding-block:var(--space-lg);border-top:1px solid var(--clr-border);text-align:left}.pa-bilan h2[data-v-6337017e]{font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2.4rem);color:var(--clr-heading);margin-bottom:var(--space-md)}.pa-bilan p[data-v-6337017e]{color:var(--clr-text-muted);font-size:1rem;line-height:1.85;max-width:680px}.bilan-grid[data-v-6337017e]{display:flex;gap:var(--space-md);flex-wrap:wrap;margin-top:var(--space-lg)}.bilan-item[data-v-6337017e]{display:flex;flex-direction:column;align-items:flex-start;padding:var(--space-md);background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-md);min-width:160px}.bilan-number[data-v-6337017e]{font-family:var(--font-display);font-size:3rem;color:var(--clr-accent);line-height:1;margin-bottom:.3rem}.bilan-label[data-v-6337017e]{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--clr-text-muted)}@media screen and (max-width:768px){.pa-meta[data-v-6337017e],.competence-header[data-v-6337017e]{flex-direction:column}.ac-grid[data-v-6337017e]{grid-template-columns:1fr}.bilan-grid[data-v-6337017e]{flex-direction:column}.pa-hero[data-v-6337017e]{text-align:center}.pa-intro-block[data-v-6337017e],.pa-competence[data-v-6337017e],.pa-bilan[data-v-6337017e]{text-align:left}}@keyframes fade-up-6337017e{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
