:root{--bg: #F9FAFB;--text: #111;--muted: #555;--accent: #673ab7;--card: #dfdfdf;--card2: #fff;--border: #e9e9e9}.dark{--bg: #121212;--text: #f0f0f0;--muted: #c8c8c8;--card: #1a1a1a;--card2: #1a1a1a;--border: #2a2a2a}*{box-sizing:border-box}html,body,#app{height:100%}body{margin:0;color:var(--text);background-color:var(--bg);background-image:url("data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20width='742'%20height='742'%20viewBox='0%200%20800%20800'%3e%3crect%20fill='%23FFFFFF'%20width='800'%20height='800'/%3e%3cg%20fill='none'%20stroke='%23EEEEEE'%20stroke-width='2.8'%3e%3cpath%20d='M769%20229L1037%20260.9M927%20880L731%20737%20520%20660%20309%20538%2040%20599%20295%20764%20126.5%20879.5%2040%20599-197%20493%20102%20382-31%20229%20126.5%2079.5-69-63'/%3e%3cpath%20d='M-31%20229L237%20261%20390%20382%20603%20493%20308.5%20537.5%20101.5%20381.5M370%20905L295%20764'/%3e%3cpath%20d='M520%20660L578%20842%20731%20737%20840%20599%20603%20493%20520%20660%20295%20764%20309%20538%20390%20382%20539%20269%20769%20229%20577.5%2041.5%20370%20105%20295%20-36%20126.5%2079.5%20237%20261%20102%20382%2040%20599%20-69%20737%20127%20880'/%3e%3cpath%20d='M520-140L578.5%2042.5%20731-63M603%20493L539%20269%20237%20261%20370%20105M902%20382L539%20269M390%20382L102%20382'/%3e%3cpath%20d='M-222%2042L126.5%2079.5%20370%20105%20539%20269%20577.5%2041.5%20927%2080%20769%20229%20902%20382%20603%20493%20731%20737M295-36L577.5%2041.5M578%20842L295%20764M40-201L127%2080M102%20382L-261%20269'/%3e%3c/g%3e%3cg%20fill='%23DDDDDD'%3e%3ccircle%20cx='769'%20cy='229'%20r='10'/%3e%3ccircle%20cx='539'%20cy='269'%20r='10'/%3e%3ccircle%20cx='603'%20cy='493'%20r='10'/%3e%3ccircle%20cx='731'%20cy='737'%20r='10'/%3e%3ccircle%20cx='520'%20cy='660'%20r='10'/%3e%3ccircle%20cx='309'%20cy='538'%20r='10'/%3e%3ccircle%20cx='295'%20cy='764'%20r='10'/%3e%3ccircle%20cx='40'%20cy='599'%20r='10'/%3e%3ccircle%20cx='102'%20cy='382'%20r='10'/%3e%3ccircle%20cx='127'%20cy='80'%20r='10'/%3e%3ccircle%20cx='370'%20cy='105'%20r='10'/%3e%3ccircle%20cx='578'%20cy='42'%20r='10'/%3e%3ccircle%20cx='237'%20cy='261'%20r='10'/%3e%3ccircle%20cx='390'%20cy='382'%20r='10'/%3e%3c/g%3e%3c/svg%3e");background-size:644px 644px;background-repeat:repeat;background-attachment:fixed;font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:18px}.dark body{background-image:url("data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20width='400'%20height='400'%20viewBox='0%200%20800%20800'%3e%3crect%20fill='%23121212'%20width='800'%20height='800'/%3e%3cg%20fill='none'%20stroke='%23444444'%20stroke-width='1'%3e%3cpath%20d='M769%20229L1037%20260.9M927%20880L731%20737%20520%20660%20309%20538%2040%20599%20295%20764%20126.5%20879.5%2040%20599-197%20493%20102%20382-31%20229%20126.5%2079.5-69-63'/%3e%3cpath%20d='M-31%20229L237%20261%20390%20382%20603%20493%20308.5%20537.5%20101.5%20381.5M370%20905L295%20764'/%3e%3cpath%20d='M520%20660L578%20842%20731%20737%20840%20599%20603%20493%20520%20660%20295%20764%20309%20538%20390%20382%20539%20269%20769%20229%20577.5%2041.5%20370%20105%20295%20-36%20126.5%2079.5%20237%20261%20102%20382%2040%20599%20-69%20737%20127%20880'/%3e%3cpath%20d='M520-140L578.5%2042.5%20731-63M603%20493L539%20269%20237%20261%20370%20105M902%20382L539%20269M390%20382L102%20382'/%3e%3cpath%20d='M-222%2042L126.5%2079.5%20370%20105%20539%20269%20577.5%2041.5%20927%2080%20769%20229%20902%20382%20603%20493%20731%20737M295-36L577.5%2041.5M578%20842L295%20764M40-201L127%2080M102%20382L-261%20269'/%3e%3c/g%3e%3cg%20fill='%23555555'%3e%3ccircle%20cx='769'%20cy='229'%20r='5'/%3e%3ccircle%20cx='539'%20cy='269'%20r='5'/%3e%3ccircle%20cx='603'%20cy='493'%20r='5'/%3e%3ccircle%20cx='731'%20cy='737'%20r='5'/%3e%3ccircle%20cx='520'%20cy='660'%20r='5'/%3e%3ccircle%20cx='309'%20cy='538'%20r='5'/%3e%3ccircle%20cx='295'%20cy='764'%20r='5'/%3e%3ccircle%20cx='40'%20cy='599'%20r='5'/%3e%3ccircle%20cx='102'%20cy='382'%20r='5'/%3e%3ccircle%20cx='127'%20cy='80'%20r='5'/%3e%3ccircle%20cx='370'%20cy='105'%20r='5'/%3e%3ccircle%20cx='578'%20cy='42'%20r='5'/%3e%3ccircle%20cx='237'%20cy='261'%20r='5'/%3e%3ccircle%20cx='390'%20cy='382'%20r='5'/%3e%3c/g%3e%3c/svg%3e")}p{text-align:justify;text-justify:inter-word}.lead,.timeline p,.footer__copy{text-align:justify}.container{width:min(1120px,92%);margin:0 auto}.header{position:sticky;top:0;z-index:20;background:color-mix(in srgb,var(--bg),transparent 10%);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-bottom:1px solid var(--border)}.header__inner{display:flex;align-items:center;gap:16px;padding:12px 0}.logo{font-weight:800;font-family:Poppins,sans-serif;text-decoration:none;color:var(--text);font-size:22px}.nav{display:none;gap:16px}.nav a{color:var(--text);text-decoration:none;font-weight:600}.actions{margin-left:auto;display:flex;align-items:center;gap:10px}.lang button{background:none;border:none;color:var(--text);cursor:pointer;font-weight:700}.lang .active{color:var(--accent)}.lang .sep{opacity:.6;margin:0 4px}.theme{border:1px solid var(--border);background:var(--card);padding:6px 10px;border-radius:8px;cursor:pointer}main{display:grid;gap:80px}.section{padding:40px 0;position:relative}.section.about,.section.projects,.footer{background-color:var(--card)}.separateur{width:100%;display:block;height:220px;background-color:var(--card);-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1000 220' preserveAspectRatio='none'><path fill='black' d='M0,90 C200,40 420,140 640,80 C800,40 900,70 1000,85 V220 H0 Z'/></svg>");mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1000 220' preserveAspectRatio='none'><path fill='black' d='M0,90 C200,40 420,140 640,80 C800,40 900,70 1000,85 V220 H0 Z'/></svg>");-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:top center;mask-position:top center;-webkit-mask-size:100% 100%;mask-size:100% 100%;margin-bottom:-140px}.separateur--gray{background-color:var(--card)}.separateur--lg{height:300px;margin-bottom:-200px}.separateur--bottom{transform:scaleY(-1);margin-bottom:0;margin-top:-140px}.separateur--bottom.separateur--lg{margin-top:-200px}.ido{margin-top:25vh}.hero__inner{display:grid;grid-template-columns:320px 1fr;gap:32px;align-items:center}.hero__media img{width:100%;height:auto;border-radius:16px;border:3px solid color-mix(in srgb,var(--accent),red 10%)}.hero h1{font-family:Poppins,sans-serif;font-size:clamp(64px,4vw + 8px,96px);line-height:1.1;margin:0}.hero h1 .accent,.title{color:var(--accent)}.lead{color:var(--muted);font-size:20px}.btn{display:inline-block;background:var(--accent);color:#fff;text-decoration:none;padding:12px 18px;border-radius:12px;margin-top:16px;font-weight:700}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.card{background:var(--card2);border:1px solid var(--border);padding:16px;border-radius:14px}.row{display:flex;gap:12px}.project-card{display:flex;flex-direction:column;gap:12px}.project-card__header{display:flex;align-items:center;gap:12px}.project-card__icon{width:48px;height:48px;flex-shrink:0;border-radius:10px;overflow:hidden;border:none;background:transparent}.project-card__icon--placeholder{border:1px solid var(--border)}.project-card__icon img{width:100%;height:100%;object-fit:contain;display:block}.project-card__header h3{margin:0;font-size:clamp(18px,1.2vw + 10px,24px)}.project-card p{flex:1;margin:0}.project-card .row{margin-top:auto}h2{font-family:Poppins,sans-serif;font-size:clamp(30px,2.6vw + 10px,44px);margin:0 0 12px}h3{font-family:Poppins,sans-serif;font-size:clamp(24px,1.6vw + 10px,32px);margin:12px 0}h4{font-weight:800;margin:8px 0}.skills__subtitle{color:var(--accent);margin-top:6px}.center{text-align:center}.web-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px;margin-bottom:24px}.web-col{background:transparent;border:0;padding:8px;border-radius:0}.web-col ul{margin:8px 0 0;padding-left:18px}.web-col li{margin:6px 0}.tech-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:18px;align-items:start}.tech{display:grid;justify-items:center;gap:8px}.tech__icon{width:64px;height:64px;border-radius:999px;display:grid;place-items:center;background:radial-gradient(120% 120% at 30% 30%,color-mix(in srgb,var(--card),#000 6%),color-mix(in srgb,var(--card),#000 18%));box-shadow:0 6px 18px #00000026,inset 0 1px #ffffff0a;border:1px solid var(--border)}.tech__icon img{width:60%;height:60%;object-fit:contain}.tech__icon span{font-weight:800;color:var(--text)}.tech__label{font-size:14px;color:var(--muted);text-align:center}.others .card h3{font-size:20px}.dark .tech__icon img[data-invert]{filter:invert(1) brightness(1.2)}.other-groups{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.other-group{background:transparent;border:0;padding:8px;border-radius:0}.other-group ul{display:none}.other-group .tech-grid{margin-top:6px}.footer{border-top:1px solid var(--border);margin-top:40px}.footer__inner{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;padding:48px 0 40px}.footer__brand{display:flex;flex-direction:column;gap:8px}.footer__name{font-family:Poppins,sans-serif;font-weight:800;font-size:20px;margin:0;color:var(--text)}.footer__tagline{margin:0;color:var(--muted);font-size:14px}.footer__contact-info{display:flex;flex-direction:column;gap:8px;margin-top:10px}.footer__contact-link{display:flex;align-items:center;gap:8px;color:var(--text);text-decoration:none;font-size:14px;transition:color .15s}.footer__contact-link:hover{color:var(--accent)}.footer__contact-link svg{flex-shrink:0;color:var(--accent)}.footer__col-title{margin:0 0 14px;font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:1px;color:var(--muted)}.footer__nav{display:flex;flex-direction:column}.footer__nav-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 24px}.footer__nav a{color:var(--text);text-decoration:none;font-size:15px;transition:color .15s}.footer__nav a:hover{color:var(--accent)}.footer__social{display:flex;flex-direction:column;gap:10px}.footer__social-link{display:flex;align-items:center;gap:10px;color:var(--text);text-decoration:none;font-size:15px;transition:color .15s}.footer__social-link:hover{color:var(--accent)}.footer__social-link svg{flex-shrink:0}.footer__bottom{border-top:1px solid var(--border);padding:16px 0}.footer__bottom-inner{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--muted)}.tl{list-style:none;padding:0;margin:0;border-left:2px solid var(--border)}.tl li{position:relative;padding:12px 0 12px 18px}.tl__dot{position:absolute;left:-6px;top:18px;width:10px;height:10px;background:var(--accent);border-radius:999px}.burger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;padding:6px;background:var(--card);border:1px solid var(--border);border-radius:8px;cursor:pointer}.burger span{display:block;width:100%;height:2px;background:var(--text);border-radius:2px;transition:transform .25s ease,opacity .25s ease}.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.burger.open span:nth-child(2){opacity:0}.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.nav-mobile{display:flex;flex-direction:column;background:color-mix(in srgb,var(--bg),transparent 5%);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid var(--border);padding:8px 0}.nav-mobile a{color:var(--text);text-decoration:none;font-weight:600;padding:12px 24px;transition:background .15s}.nav-mobile a:hover{background:var(--card)}.contact{background-color:var(--card)}.contact__lead{color:var(--muted);margin:0 auto 2rem;max-width:520px}.contact-form{max-width:600px;margin:0 auto;display:grid;gap:20px;padding:32px}.form-group{display:grid;gap:6px}.form-group label{font-weight:600;font-size:15px;color:var(--text)}.form-group input,.form-group textarea{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px 16px;color:var(--text);font-family:inherit;font-size:16px;transition:border-color .2s,box-shadow .2s;resize:vertical}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent),transparent 80%)}.form-group input:disabled,.form-group textarea:disabled{opacity:.6;cursor:not-allowed}.contact-submit{justify-self:start;cursor:pointer;transition:opacity .2s,transform .1s}.contact-submit:disabled{opacity:.65;cursor:not-allowed}.contact-submit:not(:disabled):hover{opacity:.88;transform:translateY(-1px)}.form-feedback{padding:12px 16px;border-radius:10px;font-size:15px}.form-feedback--success{background:color-mix(in srgb,#14a085,transparent 85%);color:#0d7377;border:1px solid color-mix(in srgb,#14a085,transparent 60%)}.dark .form-feedback--success{color:#4ecdc4}.form-feedback--error{background:color-mix(in srgb,#e53935,transparent 88%);color:#c62828;border:1px solid color-mix(in srgb,#e53935,transparent 65%)}.dark .form-feedback--error{color:#ef9a9a}@media (min-width: 900px){.nav{display:flex}.burger{display:none}}@media (max-width: 800px){.hero__inner{grid-template-columns:1fr}.footer__inner{grid-template-columns:1fr;gap:32px;padding:36px 0 28px}.footer__bottom-inner{flex-direction:column;gap:4px;text-align:center}}[data-animate]{opacity:0;transform:translateY(12px);transition:.6s ease}[data-animate].in{opacity:1;transform:none}html{scroll-behavior:smooth}
