body{margin:0;font-family:Inter,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background-color:#1a3d44;color:#e2e8f0}h1,h2,h3,h4,h5,h6{font-family:Space Grotesk,-apple-system,sans-serif}.construction-popup{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background-color:#f97316;color:#fff;padding:10px 24px;border-radius:50px;font-weight:600;font-size:1rem;box-shadow:0 6px 15px #f9731666;z-index:10000;pointer-events:auto;text-align:center;white-space:nowrap;display:flex;align-items:center;gap:16px}.close-popup-btn{background:none;border:none;color:#fff;font-size:1.5rem;line-height:1;cursor:pointer;padding:0;opacity:.8;transition:opacity .2s ease,transform .2s ease}.close-popup-btn:hover{opacity:1;transform:scale(1.1)}.btn-primary{padding:1rem 2.5rem;border-radius:50px;font-size:1.1rem;font-weight:600;text-decoration:none;transition:all .3s cubic-bezier(.175,.885,.32,1.275);display:inline-flex;align-items:center;justify-content:center;background-color:#63b4b8;color:#0f172a;box-shadow:0 10px 20px #0000001a;border:2px solid transparent}.btn-primary:hover{transform:translateY(-3px) scale(1.02);background-color:#fff;box-shadow:0 15px 30px #fff3}.navbar{background-color:#122b30;box-shadow:0 4px 10px #0003;position:sticky;top:0;z-index:100;width:100%}.navbar-container{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:0 2rem;height:80px}.navbar-logo{display:flex;align-items:center;text-decoration:none;gap:1rem}.navbar-logo-img{height:50px;width:auto;object-fit:contain}.navbar-logo-text{font-size:1.4rem;font-weight:700;color:#fff}.navbar-menu{display:flex;list-style:none;margin:0;padding:0}.navbar-item{display:flex;align-items:center}.navbar-link{text-decoration:none;color:#cbd5e1;font-size:1.1rem;font-weight:500;position:relative;transition:color .3s ease;padding:.5rem 0}.navbar-link:hover{color:#63b4b8}.navbar-link:after{content:"";position:absolute;width:0;height:2px;bottom:0;left:0;background-color:#63b4b8;transition:width .3s ease}.navbar-link:hover:after{width:100%}@media screen and (max-width:768px){.navbar-container{flex-direction:column;height:auto;padding:1rem;gap:1rem}}.accueil-container{background-color:#1a3d44;color:#e2e8f0;position:relative;overflow:hidden}.hero-wrapper{position:relative;overflow:hidden;min-height:calc(100vh - 80px);display:flex;align-items:center;width:100%}.hero-section{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;max-width:1200px;width:100%;margin:0 auto;padding:4rem 2rem;gap:4rem}.hero-glow{position:absolute;border-radius:50%;filter:blur(90px);z-index:0;opacity:.5}.glow-1{width:350px;height:350px;background-color:#63b4b8;top:5%;left:-50px;animation:glow1 15s infinite alternate ease-in-out}.glow-2{width:450px;height:450px;background-color:#2c5d66;bottom:-100px;right:-50px;animation:glow2 12s infinite alternate ease-in-out}@keyframes glow1{0%{transform:translate(0) scale(1)}to{transform:translate(1000px,300px) scale(2)}}@keyframes glow2{0%{transform:translate(0) scale(1)}to{transform:translate(-1400px,-400px) scale(1.2)}}.hero-text{flex:1.2;position:relative;z-index:1}.hero-text h1{font-family:Space Grotesk,-apple-system,sans-serif;font-size:clamp(3rem,6vw,5rem);font-weight:800;line-height:1.1;color:#fff;margin-bottom:.5rem;letter-spacing:-1px}.hero-text h1 span{color:#63b4b8}.hero-text h2{font-size:clamp(1.5rem,3vw,2.2rem);color:#a0aec0;font-weight:500;margin-bottom:2rem}.hero-subtitle{font-size:1.3rem;color:#a0aec0;line-height:1.6;margin-bottom:3rem;max-width:600px;font-weight:300}.hero-contact-row{display:flex;gap:1.5rem;align-items:center;margin-top:1rem}.hero-mail-btn{padding:.8rem 1.8rem;border-radius:50px;font-size:1rem;font-weight:600;text-decoration:none;background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);display:inline-flex;align-items:center;gap:.8rem;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.hero-mail-icon{font-size:1.2rem}.hero-mail-btn:hover{background:#fff3;border-color:#fff6;transform:translateY(-2px);box-shadow:0 10px 20px #0000001a}.hero-social-links{display:flex;gap:.8rem}.hero-social-btn{width:45px;height:45px;border-radius:50px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;color:#fff;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.hero-social-btn svg{width:22px;height:22px}.hero-social-btn:hover{background:#fff;color:#0f172a;transform:translateY(-2px);box-shadow:0 10px 20px #0000001a}.hero-image-wrapper{flex:.8;display:flex;justify-content:flex-end;position:relative;z-index:1}.hero-image-modern{position:relative;width:400px;height:500px;background:#1a3d441a;border-radius:20px;transform:rotate(3deg);transition:transform .5s ease}.hero-image-modern:hover{transform:rotate(0) scale(1.02)}.hero-image-modern img{width:100%;height:100%;object-fit:cover;border-radius:20px;filter:grayscale(40%) contrast(1.1);box-shadow:-20px 20px 40px #0006}.floating-badge{position:absolute;bottom:-20px;left:-40px;background:#ffffff0d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);padding:1rem 2rem;border-radius:50px;color:#fff;font-weight:600;font-size:.95rem;box-shadow:0 10px 25px #0003;animation:floatBadge 4s ease-in-out infinite alternate}@keyframes floatBadge{0%{transform:translateY(0)}to{transform:translateY(-10px)}}.content-section{padding:6rem 2rem}.alternate-bg{background-color:#2c5d66}.section-container{max-width:1200px;margin:0 auto}.section-container h2{font-size:2.2rem;color:#fff;margin-bottom:2.5rem;position:relative;display:inline-block}.section-container h2:after{content:"";position:absolute;width:50%;height:4px;bottom:-10px;left:0;background-color:#63b4b8;border-radius:2px}.creative-skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2.5rem;margin-top:3.5rem;position:relative;z-index:2}.skill-panel{background:#2c5d6626;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(99,180,184,.2);border-radius:20px;padding:2.5rem;transition:all .4s cubic-bezier(.175,.885,.32,1.275);position:relative;overflow:hidden;box-shadow:0 10px 30px #0003}.skill-panel:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,#63b4b8,transparent)}.skill-panel:hover{transform:translateY(-8px);border-color:#63b4b899;box-shadow:0 20px 40px #0006,0 0 30px #63b4b826 inset}.panel-header{display:flex;align-items:center;gap:1.2rem;margin-bottom:2.5rem}.panel-icon{font-size:2.2rem;background:#ffffff0d;padding:.8rem;border-radius:12px;border:1px solid rgba(255,255,255,.1)}.panel-header h3{font-size:1.5rem;color:#fff;font-weight:700;margin:0;letter-spacing:.5px}.skill-nodes{display:flex;flex-direction:column;gap:1.2rem}.placeholder-block{background-color:#ffffff08;border:1px dashed rgba(255,255,255,.15);border-radius:12px;padding:4rem 2rem;text-align:center;color:#cbd5e1;font-style:italic;font-size:1.1rem;transition:all .3s ease}.placeholder-block:hover{background-color:#ffffff0d;border-color:#ffffff4d}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:3.5rem;margin-top:4rem;justify-content:center}.project-card{position:relative;background:#1a3d441a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.05);border-radius:24px;overflow:hidden;transition:all .5s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 10px 30px #0000001a;display:flex;flex-direction:column}.project-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,rgba(255,255,255,.05) 0%,transparent 100%);pointer-events:none;z-index:0}.project-card:hover{transform:translateY(-10px) scale(1.02);border-color:#63b4b84d;box-shadow:0 20px 40px #0003,0 0 20px #63b4b81a}.project-image{position:relative;width:calc(100% - 2rem);margin:1rem auto 0;aspect-ratio:16 / 9;background-color:transparent;border-radius:16px;overflow:hidden;box-shadow:0 10px 20px #0003;z-index:1}.image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-size:cover;background-position:center;transition:transform .6s cubic-bezier(.175,.885,.32,1.275)}.project-card:hover .image-placeholder{transform:scale(1.08)}.project-domain{font-family:Space Grotesk,sans-serif;font-size:1.5rem;font-weight:800;color:#fff;letter-spacing:2px;text-transform:uppercase}.project-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#122b30b3;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .4s ease}.project-card:hover .project-overlay{opacity:1}.btn-project{padding:.8rem 2rem;background-color:#fff;color:#0f172a;border:none;border-radius:50px;font-weight:700;font-size:.95rem;text-decoration:none;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #fff3;transform:translateY(20px)}.project-card:hover .btn-project{transform:translateY(0)}.btn-project:hover{background-color:#63b4b8;color:#fff;box-shadow:0 6px 20px #63b4b866}.btn-project.outline{background-color:transparent;color:#fff;border:2px solid #63b4b8;box-shadow:none}.btn-project:hover{transform:scale(1.05);background-color:#7dd1d5;box-shadow:0 6px 15px #63b4b880}.btn-project.outline:hover{background-color:#63b4b833;color:#fff}.project-content{padding:2rem;flex:1;display:flex;flex-direction:column}.project-content h3{font-size:1.4rem;color:#fff;margin-bottom:.8rem;font-weight:600}.project-content p{color:#a0aec0;font-size:.95rem;line-height:1.6;margin-bottom:2rem;flex:1}.project-techs{display:flex;flex-wrap:wrap;gap:.6rem}.links-grid{display:flex;justify-content:center;gap:2.5rem;flex-wrap:wrap;margin-top:3.5rem}.link-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:1.5rem;background:#1a3d4433;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.05);padding:2.5rem 3rem;border-radius:24px;text-decoration:none;color:#e2e8f0;transition:all .4s cubic-bezier(.175,.885,.32,1.275);min-width:250px;position:relative;overflow:hidden}.link-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at top right,rgba(255,255,255,.05) 0%,transparent 60%);opacity:0;transition:opacity .4s ease}.link-card:hover{transform:translateY(-8px);background:#1a3d4480;box-shadow:0 20px 40px #0000004d}.link-card:hover:before{opacity:1}.linkedin-card:hover{border-color:#0a66c280;box-shadow:0 20px 40px #0a66c226}.github-card:hover{border-color:#6e549480;box-shadow:0 20px 40px #6e549426}.link-icon{width:70px;height:70px;display:flex;align-items:center;justify-content:center;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:15px;transition:all .4s ease}.linkedin-card:hover .link-icon{background:#0a66c2;border-color:#0a66c2;transform:scale(1.1) rotate(-5deg)}.github-card:hover .link-icon{background:#fff;border-color:#fff;transform:scale(1.1) rotate(5deg)}.link-icon img{width:100%;height:100%;object-fit:contain;filter:grayscale(1) brightness(2);transition:filter .4s ease}.linkedin-card:hover .link-icon img{filter:brightness(0) invert(1)}.github-card:hover .link-icon img{filter:none}.link-info{display:flex;flex-direction:column;gap:.4rem;z-index:1}.link-info h3{font-size:1.5rem;font-weight:700;color:#fff;margin:0;letter-spacing:-.5px}.link-info span{font-size:.95rem;color:#8db5b6;font-weight:500}.link-arrow{position:absolute;bottom:25px;right:25px;font-size:1.2rem;color:#63b4b8;opacity:0;transform:translate(-10px) translateY(10px);transition:all .4s ease}.link-card:hover .link-arrow{opacity:1;transform:translate(0) translateY(0)}.contact-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:center;margin-top:4rem;text-align:center}.contact-email-btn{position:relative;display:inline-flex;align-items:center;gap:1.2rem;background:#63b4b81a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;text-decoration:none;padding:1.5rem 3.5rem;border-radius:50px;border:1px solid rgba(99,180,184,.3);font-size:1.3rem;font-weight:600;letter-spacing:.5px;box-shadow:0 10px 30px #0000001a;transition:all .4s cubic-bezier(.175,.885,.32,1.275);overflow:hidden}.contact-email-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s ease}.contact-email-btn:hover{transform:translateY(-5px) scale(1.02);background:#63b4b833;border-color:#63b4b899;box-shadow:0 20px 40px #63b4b833}.contact-email-btn:hover:before{left:100%}.email-icon{font-size:1.6rem}.email-text{position:relative;z-index:1}.contact-subtext{margin-top:2.5rem;color:#8db5b6;font-size:1.15rem;font-weight:400;max-width:500px;line-height:1.6}@media screen and (max-width:768px){.hero-section{flex-direction:column-reverse;text-align:center;padding:3rem 1.5rem;gap:3rem}.hero-text p{margin:0 auto 2.5rem}.hero-buttons{justify-content:center;flex-direction:column;gap:1rem}.hero-text h1{font-size:2.5rem}.section-container h2:after{left:25%}.section-container{text-align:center}}.node-item{display:flex;align-items:center;gap:1rem;background:#1a3d4480;border:1px solid rgba(255,255,255,.05);padding:.6rem 1rem .6rem .6rem;border-radius:50px;transition:all .3s ease;width:100%;box-sizing:border-box}.node-item:hover{background:#63b4b826;border-color:#63b4b880;transform:scale(1.05) translate(5px);box-shadow:0 5px 15px #0003}.node-icon-wrap{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;box-shadow:0 4px 10px #0003;border:2px solid transparent;transition:border-color .3s ease;overflow:hidden}.node-icon-wrap.bg-circle{background:#fff;padding:6px}.node-icon-wrap.bg-none{background:transparent;padding:0}.node-icon-wrap img{width:100%;height:100%;object-fit:contain}.node-item:hover .node-icon-wrap{border-color:#63b4b8}.node-info{display:flex;flex-direction:column}.node-info h4{color:#e2e8f0;font-size:.95rem;margin:0 0 .2rem;font-weight:600;letter-spacing:.5px}.level-indicator{display:flex;flex-direction:column;gap:6px;margin-top:6px;width:100px}.level-text{color:#8db5b6;font-size:.7rem;text-transform:uppercase;letter-spacing:.8px;font-weight:700;line-height:1}.progress-track{width:100%;height:6px;background:#0003;border-radius:3px;overflow:hidden;border:1px solid rgba(255,255,255,.05)}.progress-fill{height:100%;background:#63b4b8;border-radius:2px;transition:width 1s cubic-bezier(.175,.885,.32,1.275),background-color .3s ease}.node-item:hover .progress-fill{background:#7dd1d5;box-shadow:0 0 5px #63b4b899}.tech-badge-small{display:inline-flex;align-items:center;gap:.5rem;background-color:#63b4b81a;padding:.3rem .8rem .3rem .3rem;border-radius:50px;border:1px solid rgba(99,180,184,.2);transition:transform .2s ease,background-color .2s ease}.tech-badge-small:hover{background-color:#63b4b833;transform:translateY(-2px)}.badge-icon-wrap{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%}.badge-icon-wrap.bg-circle{background:#fff;padding:3px}.badge-icon-wrap img{width:100%;height:100%;object-fit:contain}.tech-badge-small span{color:#63b4b8;font-size:.75rem;font-weight:700;letter-spacing:.5px}.tech-badge-fallback{background-color:#ffffff1a;color:#cbd5e1;padding:.4rem 1rem;border-radius:50px;font-size:.75rem;font-weight:600}.marquee-container{width:100%;padding:3rem 0;background-color:#122b3066;border-top:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.05);transform:rotate(-2deg) scale(1.05);margin:4rem 0;overflow:hidden;box-shadow:0 10px 30px #0003;z-index:10;position:relative}.marquee-item{font-family:Space Grotesk,-apple-system,sans-serif;font-size:clamp(3rem,5vw,4rem);font-weight:800;color:transparent;-webkit-text-stroke:1.5px rgba(255,255,255,.2);text-transform:uppercase;letter-spacing:2px;white-space:nowrap;transition:all .3s ease}.marquee-separator{font-size:clamp(2rem,4vw,3rem);color:#63b4b8;margin:0 3rem;display:inline-block}.marquee-container:hover .marquee-item{color:#fffc;-webkit-text-stroke:0px transparent}.projet-detail-container{min-height:100vh;background-color:var(--bg-primary, #0f172a)}.projet-hero{position:relative;width:100%;min-height:50vh;background-color:#122b30;background-size:cover;background-position:center}.hero-overlay{width:100%;height:100%;min-height:50vh;background:linear-gradient(to top,#0f172a,#0f172a80,#0f172a33);display:flex;flex-direction:column;justify-content:flex-end;padding:3rem 5%;box-sizing:border-box}.back-link{color:#63b4b8;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;font-size:1.1rem;transition:transform .3s ease,color .3s ease;align-self:flex-start;margin-bottom:2rem;background:#0f172a80;padding:.5rem 1rem;border-radius:50px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(99,180,184,.2)}.back-link:hover{transform:translate(-5px);color:#fff;background:#63b4b833}.hero-content h1{font-size:3.5rem;color:#fff;margin-bottom:1.5rem;font-weight:800;text-shadow:0 4px 20px rgba(0,0,0,.5)}.projet-tags{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.projet-content-section{padding:4rem 0 8rem}.projet-layout{display:flex;gap:4rem;align-items:flex-start}.projet-main-column{flex:2}.projet-sidebar{flex:1;display:flex;flex-direction:column;gap:2rem;position:sticky;top:100px}.projet-main-column h2{font-size:2rem;color:#fff;margin-bottom:2rem;font-weight:700;position:relative;display:inline-block}.projet-main-column h2:after{content:"";position:absolute;bottom:-8px;left:0;width:50px;height:4px;background-color:#63b4b8;border-radius:2px}.projet-description p{color:#cbd5e1;font-size:1.1rem;line-height:1.8;margin-bottom:1.5rem}.sidebar-box{background:#2c5d6626;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.05);border-radius:16px;padding:2rem;box-shadow:0 10px 30px #0000001a}.sidebar-box h3{font-size:1.3rem;color:#fff;margin-bottom:1.5rem;font-weight:600;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:.8rem}.info-list{list-style:none;padding:0;margin:0 0 2rem}.info-list li{color:#cbd5e1;margin-bottom:1rem;font-size:1rem;display:flex;flex-direction:column;gap:.2rem}.info-list li strong{color:#63b4b8;font-size:.85rem;text-transform:uppercase;letter-spacing:1px}.action-links{display:flex;flex-direction:column;gap:1rem}.full-width{width:100%;text-align:center;display:block;box-sizing:border-box}.techs-grid{display:flex;flex-wrap:wrap;gap:.8rem}.projet-gallery{margin-top:4rem}.projet-gallery h3{font-size:1.8rem;color:#fff;margin-bottom:2rem}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.gallery-image{width:100%;height:auto;border-radius:12px;box-shadow:0 4px 15px #0003;transition:transform .3s ease}.gallery-image:hover{transform:scale(1.02)}.media-placeholder{width:100%;height:300px;background-color:#ffffff05;border:2px dashed rgba(255,255,255,.1);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#64748b;font-style:italic}@media screen and (max-width:992px){.projet-layout{flex-direction:column}.projet-sidebar{width:100%;position:static}}@media screen and (max-width:768px){.hero-content h1{font-size:2.2rem}.projet-hero{height:40vh;min-height:300px}.back-link{margin-top:1rem}}.gallery-image.clickable{cursor:pointer}.lightbox-overlay{position:fixed;inset:0;background-color:#0f172af2;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease-out}.lightbox-content{position:relative;max-width:90vw;max-height:85vh;display:flex;flex-direction:column;align-items:center}.lightbox-content img{max-width:100%;max-height:85vh;object-fit:contain;border-radius:8px;box-shadow:0 10px 40px #00000080;animation:scaleIn .3s cubic-bezier(.175,.885,.32,1.275)}.lightbox-close{position:absolute;top:20px;right:30px;background:#ffffff1a;color:#fff;border:none;width:45px;height:45px;border-radius:50%;font-size:2rem;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,transform .2s;z-index:10000}.lightbox-close:hover{background:#ef4444;transform:rotate(90deg)}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1a;color:#fff;border:none;width:50px;height:50px;border-radius:50%;font-size:1.5rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,transform .2s;z-index:10000}.lightbox-nav:hover{background:#63b4b8;transform:translateY(-50%) scale(1.1)}.lightbox-nav.prev{left:20px}.lightbox-nav.next{right:20px}.lightbox-counter{position:absolute;bottom:-40px;color:#fff9;font-size:1.1rem;letter-spacing:2px;font-weight:500}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}@media screen and (max-width:768px){.lightbox-nav{width:40px;height:40px;font-size:1.2rem}.lightbox-nav.prev{left:10px}.lightbox-nav.next{right:10px}}
