:root{--font-sans: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;--font-display: "Space Grotesk", var(--font-sans)}body{font-family:var(--font-sans);font-optical-sizing:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6}h1,h2,.display{font-family:var(--font-display);font-weight:700;letter-spacing:.2px}:root{--cafe-noir: #4C3D19;--kombu: #354024;--moss: #889063;--tan: #CFB899;--bone: #E5D7C4;--header-bg: rgba(22,26,23,.9);--header-text: #fff;--header-border: var(--border);--btn-fg: #111;--bg: #0f1110;--surface: #161a17;--text: #EEEADF;--muted: #B9AF9B;--accent: var(--moss);--accent-2: var(--kombu);--border: #232621;--glow: rgba(255,77,109,.22)}:root[data-theme=light] .skill-track{background:#edebfa}:root[data-theme=light]{--bg: #F7F7FB;--surface: #FFFFFF;--text: #1F2937;--muted: #6B7280;--btn-fg: #fff;--accent: #6D28D9;--accent-2: #5B21B6;--border: #E5E7EB;--header-bg: rgba(255,255,255,.88);--header-text: #111827;--header-border: #E5E7EB;--glow: rgba(109, 40, 217, .16)}:root[data-theme=light] .bg-ornaments{opacity:.12}*{box-sizing:border-box}html,body{margin:0}html,body,#root{height:100%}html{scroll-behavior:smooth}body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100dvh;display:flex;flex-direction:column}main{flex:1 0 auto}section{scroll-margin-top:90px}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-2)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:44px;padding:0 1rem;background:var(--accent);color:var(--btn-fg);border:1px solid color-mix(in oklab,var(--accent-2) 30%,var(--accent) 70%);border-radius:12px;font-weight:600;cursor:pointer;transition:background .2s ease,color .2s ease,transform .15s ease,box-shadow .15s ease}.btn:hover{background:var(--accent-2);color:#fff;transform:translateY(-1px)}.btn:active{transform:translateY(0) scale(.99)}.btn:focus-visible{outline:none;box-shadow:0 0 0 3px color-mix(in oklab,var(--accent) 40%,transparent)}.btn[disabled],.btn.is-disabled{opacity:.55;cursor:not-allowed;pointer-events:none}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.section{padding:3rem 0}.site-header{position:sticky;top:0;z-index:10;background:var(--header-bg);color:var(--header-text);border-bottom:1px solid var(--header-border);-webkit-backdrop-filter:saturate(120%) blur(6px);backdrop-filter:saturate(120%) blur(6px);padding:12px 0}.site-header .container{display:flex;justify-content:space-between;align-items:center}.site-header .logo{color:var(--header-text);font-weight:700;letter-spacing:.2px}.site-header nav a{color:var(--header-text);margin-left:1rem}.site-header nav a:hover{text-decoration:underline}.site-header .btn-ghost.theme-toggle{color:var(--header-text);border-color:color-mix(in oklab,var(--header-text) 35%,transparent);background:transparent}.site-header .btn-ghost.theme-toggle:hover{background:color-mix(in oklab,var(--header-text) 12%,transparent)}.hero{padding:5rem 0}.hero .container{text-align:center}.hero h1{font-size:clamp(2rem,5vw,3rem);margin:0 0 .5rem}.hero p{margin:0 auto 1.25rem;color:var(--muted);max-width:60ch}.skills{padding:3rem 0}.skills .container{max-width:1200px}.skill{margin:12px 0 18px}.skill-header{display:flex;justify-content:space-between;font-weight:600;margin-bottom:6px}.skill-track{height:12px;background:var(--tan);border-radius:9999px;overflow:hidden;box-shadow:inset 0 1px 2px #0000002e}.skill-fill{height:100%;width:0;background:var(--accent);border-radius:inherit;transition:width .9s ease-out}.skills .container{max-width:1200px;display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:start}.skills-intro p{color:var(--muted);margin:.25rem 0 .75rem}.skills-intro ul{margin:0 0 1rem 1.1rem}.skills-intro li{margin:.25rem 0}.skills-bars .skill{margin:14px 0 20px}@media (max-width: 900px){.skills .container{grid-template-columns:1fr}.skills-intro{order:1}.skills-bars{order:2}}@media (prefers-reduced-motion: reduce){.skill-fill{transition:none}}.projets .grid,.projects .grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:clamp(14px,2.4vw,22px);align-items:start}@media (max-width:900px){.projets .grid{grid-template-columns:1fr 1fr}}@media (max-width:600px){.projets .grid{grid-template-columns:1fr}}.card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:1rem;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.card:hover{transform:translateY(-2px);box-shadow:0 18px 36px var(--glow);border-color:color-mix(in oklab,var(--accent) 35%,var(--border))}.about p,.contact p{color:var(--muted)}.about ul{margin:.5rem 0 0 1rem}.about li{margin:.25rem 0}.contact{margin-bottom:120px}.site-footer{margin-top:2rem;border-top:1px solid var(--border);background:#161a1799;padding:18px 0}.site-footer .container{margin:0 auto;text-align:center}.bg-ornaments{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.18}.bg-ornaments:before,.bg-ornaments:after{content:"";position:absolute;width:60vmax;height:60vmax;border-radius:50%;filter:blur(40px);will-change:transform}.bg-ornaments:before{left:-12vmax;top:-12vmax;background:radial-gradient(circle at 30% 30%,var(--accent),transparent 60%);animation:blobMove1 24s ease-in-out infinite}.bg-ornaments:after{right:-16vmax;bottom:-16vmax;background:radial-gradient(circle at 70% 70%,var(--accent-2),transparent 60%);animation:blobMove2 32s ease-in-out infinite}@keyframes blobMove1{0%{transform:translateZ(0) scale(1)}50%{transform:translate3d(10vmax,6vmax,0) scale(1.08)}to{transform:translateZ(0) scale(1)}}@keyframes blobMove2{0%{transform:translateZ(0) scale(1)}50%{transform:translate3d(-8vmax,-5vmax,0) scale(1.12)}to{transform:translateZ(0) scale(1)}}.site-header,main,.site-footer{position:relative;z-index:1}@media (prefers-reduced-motion: reduce){.bg-ornaments,.bg-ornaments:before,.bg-ornaments:after{animation:none!important}}.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border)}.btn-ghost:hover{background:var(--surface);color:var(--text)}.theme-toggle{margin-left:12px}.site-header nav{display:flex;align-items:center;gap:12px}.form{display:grid;gap:12px;margin-top:1rem}.input,.textarea{width:100%;padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text)}.input:focus,.textarea:focus{outline:2px solid var(--accent);outline-offset:2px}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.project-card:hover{transform:translateY(-2px);box-shadow:0 18px 36px var(--glow)}.pc-media img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block}.pc-body{padding:16px}.pc-title{margin:.2rem 0 .4rem;font-size:1.1rem}.pc-desc{margin:0 0 .8rem;color:var(--muted)}.pc-section h4{margin:.4rem 0;font-size:1rem}.pc-skills{display:flex;flex-wrap:wrap;gap:8px;margin:0;padding:0;list-style:none}.chip{background:#ffffff0f;border:1px solid var(--border);padding:.25rem .55rem;border-radius:9999px;font-size:.85rem}.pc-details{margin:.6rem 0 .9rem;border:1px solid var(--border);border-radius:10px;padding:.6rem .75rem}.pc-details summary{cursor:pointer;font-weight:600;list-style:none}.pc-details[open]{border-color:color-mix(in oklab,var(--accent) 35%,var(--border))}.pc-challenges{margin:.5rem 0 0 1rem}.pc-challenges li{margin:.35rem 0}.pc-actions{display:flex;gap:10px;flex-wrap:wrap}.btn.btn-outline{background:transparent;color:var(--accent);border:1.5px solid var(--accent)}.btn.btn-outline:hover{background:var(--accent);color:var(--btn-fg)}.pc-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;flex-wrap:wrap}.pc-actions{display:flex;gap:12px;flex-wrap:wrap}.tech-icons{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}.tech-icon{font-size:20px;line-height:1;filter:grayscale(100%) opacity(.8);transition:filter .2s,transform .2s}.project-card:hover .tech-icon{filter:none;opacity:1;transform:translateY(-1px)}@media (max-width:520px){.tech-icon{font-size:18px}}.timeline{list-style:none;position:relative;margin:1.25rem 0 0;padding-left:64px}.timeline:before{content:"";position:absolute;left:22px;top:0;bottom:0;width:2px;background:var(--border)}.tl-item{position:relative;margin:18px 0;opacity:0;transform:translateY(8px);transition:opacity .45s ease,transform .45s ease}.tl-item.is-in{opacity:1;transform:none}.tl-marker{position:absolute;left:-28px;top:.9rem;width:16px;height:16px;border-radius:50%;background:var(--accent);border:2px solid color-mix(in oklab,var(--accent) 50%,#0000);box-shadow:0 0 0 6px color-mix(in oklab,var(--accent) 18%,transparent)}.tl-content.card{padding:12px 14px}.tl-header{color:var(--muted);font-size:.92rem}.tl-title{margin:.2rem 0 .25rem;font-size:1.05rem}.tl-desc{margin:0;color:var(--muted)}.tl-tags{display:flex;gap:8px;margin:.6rem 0 0;padding:0;list-style:none}@media (prefers-reduced-motion: reduce){.tl-item{transition:none;opacity:1;transform:none}}.reveal{opacity:0;transform:translateY(10px);transition:opacity .5s ease,transform .5s ease;transition-delay:var(--d, 0ms);will-change:opacity,transform}.reveal.is-in{opacity:1;transform:none}@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none;transition:none}}.header-row{display:flex;justify-content:space-between;align-items:center}.primary-nav{display:flex;align-items:center;gap:12px}.nav-toggle{display:none;align-items:center;justify-content:center;padding:6px 10px;border-radius:10px}@media (min-width: 681px){.primary-nav{display:flex;align-items:center;gap:12px;position:static;padding:0;background:transparent;box-shadow:none}.nav-contact.btn{background:transparent;color:var(--header-text);border:0;padding:0}.nav-contact.btn:hover{background:transparent;text-decoration:underline;color:var(--header-text)}}@media (max-width: 680px){.primary-nav{position:static;display:flex;align-items:center;gap:12px;padding:0;background:transparent;border:0;box-shadow:none}.primary-nav a{display:none}.primary-nav .nav-contact{display:inline-flex}.theme-toggle{display:none}.site-header nav a{margin-left:0}}.nav-toggle{display:none!important}.no-scroll{overflow:auto}.readmore-toggle{margin-top:12px}.readmore-panel{margin-top:12px;overflow:hidden;max-height:0;opacity:0;transition:max-height .4s ease,opacity .3s ease}.readmore-panel.is-open{max-height:1600px;opacity:1}.prose h3{margin:.6rem 0 .35rem}.prose p{margin:0 0 .7rem;color:var(--muted)}.prose ul{margin:.4rem 0 .8rem 1.2rem}.contact .container{max-width:800px}.contact-lead{font-size:1.1rem;line-height:1.6;margin-bottom:2rem;color:var(--muted)}.contact-info-box{background:#ffffff0d;padding:1.5rem;border-radius:8px;margin-bottom:2rem;border:1px solid var(--border)}.contact-info-box h2{font-size:1.2rem;margin-bottom:1rem}.contact-info-box p{margin-bottom:.5rem;color:var(--text)}.contact-info-box p:last-child{margin-bottom:0}.contact-info-box strong{font-weight:600}.contact-info-box a{color:var(--accent);transition:color .2s ease}.contact-info-box a:hover{color:var(--accent-2)}.contact-section-title{font-size:1.5rem;margin-bottom:1rem}.contact-intro-text{margin-bottom:1.5rem;color:var(--muted)}.contact-why-box{margin-top:3rem;padding:1.5rem;background:#ffffff08;border-radius:8px;border:1px solid var(--border)}.contact-why-box h2{font-size:1.2rem;margin-bottom:1rem}.contact-why-box ul{padding-left:1.5rem;line-height:1.8;list-style-type:disc;margin:0}.contact-why-box li{margin-bottom:.5rem}.contact-tip{opacity:.7;font-size:.9rem;margin-top:1rem}select.input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23889063' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}:root[data-theme=light] select.input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%236D28D9' d='M6 8L0 0h12z'/%3E%3C/svg%3E")}select.input{font-size:.85rem;font-weight:400;color:var(--text);font-family:var(--font-sans)}select.input option[value=""]{color:var(--muted);font-style:italic;font-size:.85rem}select.input option{background:var(--surface);color:var(--text);padding:10px;font-weight:400}select.input option:checked{background:var(--accent);color:var(--btn-fg);font-weight:600}.merci-container{max-width:700px;text-align:center}.merci-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:3rem 2rem;margin-top:2rem}.merci-icon{font-size:3rem;margin-bottom:1rem;filter:grayscale(0)}.merci-card h1{margin-bottom:1rem}.merci-lead{font-size:1.1rem;color:var(--muted);margin-bottom:2rem;line-height:1.6}.merci-steps-box{background:#ffffff08;border:1px solid var(--border);border-radius:10px;padding:1.5rem;margin-bottom:2rem;text-align:left}.merci-steps-box h2{font-size:1.1rem;margin-bottom:.75rem;color:var(--text)}.merci-steps-box ul{margin:0;padding-left:1.5rem;color:var(--muted);line-height:1.8;list-style-type:disc}.merci-steps-box li{margin-bottom:.25rem}.merci-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.merci-footer-text{font-size:.9rem;color:var(--muted);margin-top:2rem;margin-bottom:0}.merci-footer-text a{color:var(--accent)}.merci-footer-text a:hover{color:var(--accent-2)}
