body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}body{background:#0d0d0f;color:#fff}#root,body,html{margin:0}.app{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1 1}.container{font-family:Open Sans,sans-serif}#root,body,html{height:100%}.navbar{border-bottom:1px solid #1e293b;display:flex;justify-content:space-between;padding:20px 40px;text-transform:uppercase}.navbar .logo{font-size:20px}.navbar .nav-links a{color:#d4cebf;margin-left:20px;text-decoration:none;transition:color .3s}.navbar .nav-links a:hover{color:#4c5057}.page{margin-top:40px}.page h1{font-size:32px;margin-bottom:20px}.page h2{font-size:24px;margin-bottom:15px}.page p{line-height:1.6}.skills-list{display:flex;flex-wrap:wrap;gap:10px}.skills-list .skill{background:#f5f5f5;border-radius:6px;padding:10px 15px}.footer{background-color:#0b1623;color:#fff;padding:20px;text-align:center}.about-section{align-items:center;display:flex;flex-direction:row;justify-content:space-evenly;padding:4rem 0}@media(max-width:640px){.about-section .about-text-container{margin-bottom:2rem}.about-section{flex-direction:column;padding:10px}}.about-section .techno-label{margin-bottom:1.5rem}.about-section .about-text{color:#e5e7eb;font-size:16px;line-height:1.8;max-width:640px}.about-section .about-text p{margin:0 0 1rem}.about-section .about-text p:last-child{margin:0}.about-section .about-divider{border:none;border-right:1px solid #1f2937;margin:2.5rem 0}.about-section .techno-grid{align-items:center;display:flex;flex-wrap:wrap;gap:24px}.about-section .tech-item{align-items:center;display:flex;gap:8px}.about-section .tech-icon{height:24px;object-fit:contain;width:24px}.about-section .tech-name{color:#9ca3af;font-size:13px}.cards-section{align-items:center;border-top:.5px solid #ffffff12;display:flex;justify-content:center;min-height:60vh}@media(max-width:640px){.cards-section{padding:0 24px 40px}}.cards-grid{display:flex;flex-direction:column;gap:12px}@media(max-width:700px){.cards-grid{flex-direction:column}}.cards-grid .card{background:#111114;border:.5px solid #ffffff12;border-radius:14px;cursor:pointer;max-width:350px;overflow:hidden;padding:24px 20px;position:relative;transition:border-color .2s,transform .15s}.cards-grid .card:hover{border-color:#ffffff29;transform:translateY(-3px)}.cards-grid .card:focus-visible{outline:2px solid #7f77dd;outline-offset:2px}.cards-grid .card-top-bar{border-radius:14px 14px 0 0;height:2px;left:0;position:absolute;right:0;top:0}.cards-grid .card-icon-wrap{align-items:center;border-radius:10px;display:flex;height:40px;justify-content:center;margin-bottom:16px;width:40px}.cards-grid .card-title{color:#e0e0e0;font-size:15px;font-weight:500;margin-bottom:8px}.cards-grid .card-desc{color:#e0e0e0;font-size:12px;line-height:1.65;margin-bottom:20px}.cards-grid .card-footer{align-items:center;display:flex;gap:8px;justify-content:space-between}.cards-grid .card-tags{display:flex;flex-wrap:wrap;gap:4px}.cards-grid .ctag{background:#ffffff0a;border:.5px solid #ffffff12;border-radius:4px;color:#555;font-size:10px;padding:2px 6px}.cards-grid .card-arrow{color:#333;flex-shrink:0;font-size:14px;transition:color .15s,transform .15s}.card:hover .cards-grid .card-arrow{color:#888;transform:translateX(3px)}.modal-overlay{align-items:center;background:#000000b3;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1000}.modal{background:#fff;border:.5px solid #0000001a;border-radius:14px;max-height:90vh;max-width:720px;overflow-y:auto;padding:24px 20px;width:100%}.modal-header{align-items:center;border-bottom:.5px solid #0000001a;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.modal-header h2{color:#111;font-size:16px;font-weight:500;margin:0}.modal-title-group{align-items:center;display:flex;gap:8px}.modal-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.close-btn{align-items:center;background:#0000;border:.5px solid #0000002e;border-radius:50%;color:#555;cursor:pointer;display:flex;font-size:12px;height:28px;justify-content:center;transition:background .15s;width:28px}.close-btn:hover{background:#f3f3f3}.cat-pills{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px}.pill{background:#0000;border:1px solid #0000;border-radius:99px;cursor:pointer;font-size:11px;font-weight:500;opacity:.5;padding:4px 10px;transition:opacity .15s}.pill.active,.pill:hover{opacity:1}.pill-all{background:#eeedfe;border-color:#afa9ec;color:#3c3489}.pill-fw{background:#e6f1fb;border-color:#85b7eb;color:#0c447c}.pill-db{background:#e1f5ee;border-color:#5dcaa5;color:#085041}.pill-ops{background:#faeeda;border-color:#ef9f27;color:#633806}.pill-lang{background:#f1efe8;border-color:#b4b2a9;color:#444441}.skills-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(145px,1fr))}.skill-card{align-items:center;background:#f9f9f9;border:.5px solid #00000014;border-radius:8px;display:flex;gap:10px;padding:10px 12px;transition:border-color .15s}.skill-card:hover{border-color:#0000002e}.skill-card p{color:#111;font-size:13px;font-weight:500;margin:0}.skill-card span{color:#888;font-size:11px}.modal-hint{border-top:.5px solid #00000014;color:#aaa;font-size:11px;margin-top:16px;padding-top:12px;text-align:center}.icon{flex-shrink:0;font-size:22px;transition:transform .2s}.icon:hover{transform:scale(1.15)}.html{color:#e14e1d}.css{color:#1572b6}.js{color:#f7df1e}.php{color:#777bb3}.react{color:#08d8ff}.angular{color:#d6002f}.nest{color:#e0234e}.next{color:#000}.node{color:#44883e}.sass{color:#cb6e9b}.postgres{color:#336791}.mongo{color:#4db33d}.docker{color:#2496ed}.git{color:#f05032}.gitlab{color:#fc6d26}.figma{color:#f24e1e}.parcours{padding:8px 0}.parcours .filter-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:28px}.parcours .ftag{background:#0000;border:1px solid #0000;border-radius:50px;cursor:pointer;font-size:11px;font-weight:500;opacity:.5;padding:4px 10px;transition:opacity .15s}.parcours .ftag.on,.parcours .ftag:hover{opacity:1}.parcours .ftag-all{background:#eeedfe;border-color:#afa9ec;color:#3c3489}.parcours .ftag-form{background:#e1f5ee;border-color:#5dcaa5;color:#085041}.parcours .ftag-exp{background:#e6f1fb;border-color:#85b7eb;color:#0c447c}.parcours .ftag-stage{background:#faeeda;border-color:#ef9f27;color:#633806}.parcours .timeline{padding-left:28px;position:relative}.parcours .timeline:before{background:#0000001f;bottom:6px;content:"";left:7px;position:absolute;top:6px;width:1.5px}.parcours .entry{margin-bottom:20px;position:relative}.parcours .entry:last-child{margin-bottom:0}.parcours .dot{border:2.5px solid #fff;border-radius:50%;box-shadow:0 0 0 1px #0000001a;height:15px;left:-28px;position:absolute;top:5px;width:15px}.parcours .parcours-card{background:#fff;border:.5px solid #0000001a;border-radius:12px;padding:14px 16px;transition:border-color .15s}.parcours .parcours-card:hover{border-color:#00000038}.parcours .entry--current .parcours-card{border:1.5px solid #85b7eb}.parcours .card-top{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:4px}.parcours .card-left{display:flex;flex-direction:column;gap:3px}.parcours .type-badge{align-items:center;border-radius:99px;display:inline-flex;font-size:10px;font-weight:500;margin-bottom:2px;padding:2px 7px;width:-webkit-fit-content;width:fit-content}.parcours .badge-form{background:#e1f5ee;color:#085041}.parcours .badge-exp{background:#e6f1fb;color:#0c447c}.parcours .badge-stage{background:#faeeda;color:#633806}.parcours .card-title{font-size:14px;font-weight:500}.parcours .card-org{color:#888;font-size:12px}.parcours .card-date{color:#aaa;flex-shrink:0;font-size:11px;padding-top:3px;white-space:nowrap}.parcours .card-desc{border-top:.5px solid #00000014;color:#555;font-size:12px;line-height:1.6;margin-top:10px;padding-top:10px}.parcours .parcours-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}.parcours .parcours-tag{background:#f5f5f5;border:.5px solid #00000014;border-radius:4px;color:#666;font-size:10px;padding:2px 7px}.service{padding:4px 0 8px}.service-intro{border-bottom:.5px solid #0000001a;margin-bottom:24px}.service-label{color:#000;font-size:12px;font-weight:500;letter-spacing:.08em;margin-bottom:8px;text-transform:uppercase}.service-title{color:#111;font-size:18px;font-weight:500;margin-bottom:2px}.service-sub{color:#666;font-size:13px}.service-stats{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr);margin-bottom:24px}.stat{align-items:center;background:#f5f5f5;border-radius:8px;display:flex;flex-direction:column;gap:4px;padding:14px 12px}.stat-num{color:#111;font-size:22px;font-weight:500}.stat-lbl{color:#888;font-size:11px;text-align:center}.service-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-bottom:24px}.scard{background:#fff;border:.5px solid #0000001a;border-radius:12px;overflow:hidden;padding:16px;position:relative;transition:border-color .15s}.scard:hover{border-color:#00000038}.scard-accent{border-radius:12px 12px 0 0;height:3px;left:0;position:absolute;right:0;top:0}.scard-icon{align-items:center;border-radius:8px;display:flex;flex-shrink:0;height:36px;justify-content:center;margin-bottom:12px;width:36px}.scard-title{color:#111;font-size:13px;font-weight:500;margin-bottom:6px}.scard-desc{color:#666;font-size:12px;line-height:1.6}.scard-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:10px}.stag{background:#f5f5f5;border:.5px solid #00000014;border-radius:4px;color:#666;font-size:10px;padding:2px 6px}.service-cta{align-items:center;background:#f9f9f9;border:.5px solid #0000001a;border-radius:12px;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;padding:16px 18px}.cta-title{color:#111;font-size:13px;font-weight:500;margin-bottom:3px}.cta-sub{color:#888;font-size:12px}.cta-btn{background:#fff;border:.5px solid #0000002e;border-radius:8px;color:#111;cursor:pointer;font-size:12px;font-weight:500;padding:8px 16px;text-decoration:none;transition:background .15s;white-space:nowrap}.cta-btn:hover{background:#f0f0f0}.contact{align-items:center;background:radial-gradient(circle at bottom left,#1a2a4f 26%,#101c30 39%,#0b1623 69%);color:#fff;display:flex;justify-content:center;min-height:70vh;padding:40px}.contact-container{display:flex;gap:60px;justify-content:space-between;max-width:1200px;width:100%}.contact-left{flex:1 1}.contact-left h1{font-size:36px;font-weight:600;margin-bottom:20px}.contact-left h1 span{-webkit-text-fill-color:#0000;background:#534ab7;-webkit-background-clip:text}.contact-left h2{font-weight:400;margin-bottom:40px;opacity:.8}.contact-info{display:flex;gap:60px}.contact-info h3{font-size:14px;margin-bottom:10px;opacity:.6}.contact-info a{color:#fff;text-decoration:none}.contact-info .icons{cursor:pointer;display:flex;font-size:20px;gap:15px}.contact-info .icons svg{transition:.3s}.contact-info .icons svg:hover{color:#534ab7}.contact-right{flex:1 1}.contact-form{display:flex;flex-direction:column;gap:10px}.contact-form h2{font-weight:500;margin-bottom:20px}.contact-form label{font-size:14px;opacity:.7}.contact-form input,.contact-form textarea{background:#0000;border:1px solid #2c3e50;border-radius:30px;color:#fff;outline:none;padding:15px}.contact-form textarea{border-radius:20px;min-height:120px;resize:none}.contact-form button{background:#534ab7;border:none;border-radius:30px;color:#fff;cursor:pointer;margin-top:10px;padding:12px;transition:.3s;width:140px}.contact-form button:hover{transform:scale(1.05)}.status{font-size:14px;margin-top:10px}@media(max-width:900px){.contact-container{flex-direction:column;text-align:center}.contact-info{justify-content:center}.contact-form button{margin:0 auto}}.hero{align-items:center;background:#0d0d0f;display:flex;gap:100px;justify-content:space-evenly;min-height:80vh}@media(max-width:900px){.hero{flex-direction:column;gap:40px;text-align:center}}@media(max-width:640px){.hero{padding:48px 24px 40px}}.hero-inner{flex:1 1;max-width:600px}.hero-image{flex-shrink:0}.hero-image>img{height:70vh;object-fit:contain;width:100%}@media(max-width:900px){.hero-image>img{max-height:300px}}.hero-eyebrow{align-items:center;display:flex;gap:8px;margin-bottom:28px}.hero-dot{animation:pulse 2.2s ease-in-out infinite;background:#1d9e75;border-radius:50%;height:7px;width:7px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.hero-status{color:#1d9e75;font-size:11px;font-weight:500;letter-spacing:.05em}.hero-name{margin-bottom:2px}.hero-name,.hero-role{color:#f0f0f0;font-size:clamp(32px,5vw,52px);font-weight:500;line-height:1.1}.hero-role{margin-bottom:32px}.hero-accent{color:#7f77dd}.hero-desc{font-size:15px;line-height:1.8;margin-bottom:40px;max-width:560px}.hero-actions{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:60px}.btn-primary{background:#7f77dd;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:10px 20px;text-decoration:none;transition:background .15s}.btn-primary:hover{background:#534ab7}.btn-ghost{align-items:center;background:#0000;border:.5px solid #ffffff1a;border-radius:8px;color:#777;cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;padding:10px 20px;text-decoration:none;transition:border-color .15s,color .15s}.btn-ghost:hover{border-color:#ffffff38;color:#bbb}.btn-link{text-decoration:none}.hero-meta{border-top:.5px solid #ffffff12;display:flex;flex-wrap:wrap;gap:36px;padding-top:28px}.meta-item{display:flex;flex-direction:column;gap:4px}.meta-num{color:#e0e0e0;font-size:18px;font-weight:500}.meta-lbl{color:#b1b1b1;font-size:11px}.service-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff08;border:1px solid #ffffff1a;border-radius:15px;padding:20px;transition:.3s;width:400px}.service-card:hover{box-shadow:0 0 20px #ff4ecd4d;transform:translateY(-5px)}.service-card:nth-child(2){margin-left:200px}@media(max-width:900px){.service-card:nth-child(2){margin-left:0}}.service-card:nth-child(3){margin-left:0}@media(max-width:900px){.service-card{margin-left:0;width:100%}}.projects{align-items:center;background:#0d0d0f;border-top:.5px solid #ffffff12;display:flex;flex-direction:column;min-height:70vh}@media(max-width:640px){.projects{padding:40px 24px}}.projects .projects-description{margin-bottom:24px;text-align:center}.projects-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin:20px 0;max-width:900px}@media(max-width:900px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:560px){.projects-grid{grid-template-columns:1fr}}.projects-grid .card{background:#fff;border:.5px solid #ffffff12;border-radius:14px;cursor:pointer;display:flex;flex-direction:column;overflow:hidden;padding:20px;position:relative;transition:border-color .2s,transform .15s}.projects-grid .card:hover{border-color:#ffffff29;transform:translateY(-4px)}.projects-grid .card:focus-visible{outline:2px solid #7f77dd;outline-offset:2px}.projects-grid .card-accent-bar{height:2px;left:0;position:absolute;right:0;top:0}.projects-grid .card-image{align-items:center;aspect-ratio:16/9;display:flex;justify-content:center;overflow:hidden;width:100%}.projects-grid .card-image img{height:auto;max-height:100%;max-width:100%;width:auto}.projects-grid .card-placeholder{align-items:center;display:flex;height:100%;justify-content:center;width:100%}.projects-grid .card-placeholder span{font-size:48px;font-weight:500;opacity:.25}.projects-grid .card-content{flex:1 1;padding:14px 16px 10px}.projects-grid .card-top{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.projects-grid .card-status{border-radius:99px;font-size:10px;font-weight:500;padding:2px 7px}.projects-grid .status-done{background:#1d9e7526;color:#1d9e75}.projects-grid .status-wip{background:#ba751726;color:#ba7517}.projects-grid .status-concept{background:#7f77dd26;color:#7f77dd}.projects-grid .card-year{color:#444;font-size:11px}.projects-grid .card-title{color:#555;font-size:14px;font-weight:500;line-height:1.35;margin:0 0 4px}.projects-grid .card-desc{color:#555;display:block;font-size:12px;margin-bottom:10px}.projects-grid .card-footer{align-items:center;border-top:.5px solid #ffffff0d;display:flex;justify-content:space-between;padding:10px 16px 14px}.projects-grid .card-cta{color:#444;font-size:12px;transition:color .15s}.card:hover .projects-grid .card-cta{color:#888}.projects-grid .card-ext-link{color:#444;font-size:13px;transition:color .15s}.projects-grid .card-ext-link:hover{color:#ff4ecd}.detail-page{background:#0d0d0f;min-height:100vh}.detail-nav{align-items:center;border-bottom:.5px solid #ffffff12;display:flex;gap:16px;justify-content:space-between;padding:20px 48px}@media(max-width:640px){.detail-nav{padding:16px 24px}}.back-btn{background:#0000;border:none;color:#555;cursor:pointer;font-size:12px;padding:0;transition:color .15s;white-space:nowrap}.back-btn:hover{color:#aaa}.detail-breadcrumb{align-items:center;color:#444;display:flex;font-size:12px;gap:6px}.bc-sep{color:#333}.bc-current{color:#777;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.detail-layout{grid-gap:32px;align-items:flex-start;display:grid;gap:32px;grid-template-columns:1fr 268px;margin:0 auto;max-width:1000px;padding:40px 48px 80px}@media(max-width:820px){.detail-layout{grid-template-columns:1fr}}@media(max-width:640px){.detail-layout{padding:28px 24px 60px}}.detail-header{margin-bottom:24px}.detail-header-meta{align-items:center;display:flex;gap:10px;margin-bottom:12px}.card-status{border-radius:99px;font-size:10px;font-weight:500;padding:2px 7px}.status-done{background:#1d9e7526;color:#1d9e75}.status-wip{background:#ba751726;color:#ba7517}.status-concept{background:#7f77dd26;color:#7f77dd}.detail-year{color:#444;font-size:11px}.detail-title{color:#f0f0f0;font-size:clamp(22px,3.5vw,32px);font-weight:500;line-height:1.2;margin-bottom:10px}.detail-tagline{color:#666;font-size:14px;line-height:1.65;margin-bottom:14px}.detail-tags{display:flex;flex-wrap:wrap;gap:5px}.ctag{background:#ffffff0a;border:.5px solid #ffffff12;border-radius:4px;color:#555;font-size:10px;padding:2px 6px}.detail-bar{border-radius:2px;height:2px;margin-bottom:28px;opacity:.55}.detail-image{border:.5px solid #ffffff14;border-radius:10px;margin-bottom:36px;overflow:hidden}.detail-image img{display:block;object-fit:cover;width:100%}.detail-image-placeholder{align-items:center;aspect-ratio:16/9;border:.5px solid;border-radius:10px;display:flex;font-size:13px;justify-content:center;margin-bottom:36px;opacity:.45;width:100%}.detail-section{margin-bottom:36px}.detail-section-title{border-bottom:.5px solid #ffffff0f;color:#555;font-size:12px;font-weight:500;letter-spacing:.06em;margin-bottom:14px;padding-bottom:10px;text-transform:uppercase}.detail-description{color:#777;font-size:14px;line-height:1.85;white-space:pre-line}.detail-highlights{display:flex;flex-direction:column;gap:10px;list-style:none}.highlight-item{align-items:flex-start;color:#888;display:flex;font-size:13px;gap:10px;line-height:1.5}.highlight-dot{border-radius:50%;flex-shrink:0;height:6px;margin-top:6px;width:6px}.detail-screenshots{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.detail-screenshots img{border:.5px solid #ffffff12;border-radius:8px;display:block;object-fit:cover;width:100%}.detail-project-nav{border-top:.5px solid #ffffff0f;display:flex;gap:12px;justify-content:space-between;margin-top:8px;padding-top:28px}.project-nav-btn{background:#ffffff08;border:.5px solid #ffffff12;border-radius:10px;cursor:pointer;display:flex;flex-direction:column;gap:3px;max-width:48%;padding:12px 14px;text-align:left;transition:border-color .15s}.project-nav-btn:hover{border-color:#ffffff26}.project-nav-btn--right{margin-left:auto;text-align:right}.nav-dir{color:#444;font-size:10px}.nav-name{color:#888;font-size:12px;line-height:1.4}.detail-sidebar{display:flex;flex-direction:column;gap:12px;position:-webkit-sticky;position:sticky;top:24px}.sidebar-card{background:#111114;border:.5px solid #ffffff12;border-radius:12px;padding:16px}.sidebar-title{color:#444;font-size:10px;font-weight:500;letter-spacing:.07em;margin-bottom:12px;text-transform:uppercase}.sidebar-rows{display:flex;flex-direction:column;gap:8px}.sidebar-row{display:flex;font-size:12px;gap:8px;justify-content:space-between}.sidebar-row-label{color:#444;flex-shrink:0}.sidebar-row-value{color:#888;text-align:right}.sidebar-stack{display:flex;flex-wrap:wrap;gap:5px}.stack-tag{background:#ffffff0a;border:.5px solid #ffffff12;border-radius:4px;color:#666;font-size:11px;padding:3px 8px}.sidebar-links{display:flex;flex-direction:column;gap:8px}.sidebar-link-btn{align-items:center;border:.5px solid;border-radius:8px;display:flex;font-size:12px;font-weight:500;gap:6px;justify-content:center;padding:8px 12px;text-decoration:none;transition:opacity .15s}.sidebar-link-btn:hover{opacity:.72}.sidebar-link-ghost{border-color:#ffffff1a;color:#666}.sidebar-link-none{color:#333;font-size:12px}.detail-notfound{align-items:center;background:#0d0d0f;color:#555;display:flex;flex-direction:column;font-size:14px;gap:16px;justify-content:center;min-height:100vh}.detail-notfound button{background:#0000;border:.5px solid #ffffff1a;border-radius:8px;color:#666;cursor:pointer;font-size:12px;padding:8px 16px;transition:color .15s}.detail-notfound button:hover{color:#aaa}
/*# sourceMappingURL=main.5a95704f.css.map*/