@import url("https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500;1,600;1,700&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&display=swap");:root{--cream:#f5f0eb;--beige:#e8e0d8;--beige-light:#ede7e0;--white:#fefdfb;--black:#1a1a1a;--gray:#6b6b6b;--gray-light:#9a9a9a;--gray-border:#e0d8d0;--font-display:"Playfair Display",Georgia,serif;--font-body:"DM Sans",-apple-system,sans-serif;--ease:cubic-bezier(0.22,1,0.36,1);--radius-card:20px;--radius-btn:50px}*,:after,:before{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background-color:var(--cream);color:var(--black);line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}button{font-family:var(--font-body);cursor:pointer;border:none;background:none}img{max-width:100%;display:block}ol,ul{list-style:none}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:500;line-height:1.2}::selection{background-color:var(--beige);color:var(--black)}input,textarea{font-family:var(--font-body)}.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:24px 48px;display:flex;align-items:center;justify-content:space-between;transition:all .5s var(--ease)}.nav.scrolled{background:hsla(30,33%,94%,.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:16px 48px;box-shadow:0 1px 0 var(--gray-border)}.nav-logo{font-family:var(--font-body);font-size:16px;font-weight:600;letter-spacing:2px;text-transform:lowercase;color:var(--black)}.nav-links{display:flex;gap:40px;align-items:center}.nav-link{font-size:12px;text-transform:uppercase;letter-spacing:1.5px;font-weight:500;color:var(--gray);transition:color .4s var(--ease);position:relative}.nav-link:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--black);transition:width .4s var(--ease)}.nav-link.active,.nav-link:hover{color:var(--black)}.nav-link.active:after,.nav-link:hover:after{width:100%}.burger{display:none;flex-direction:column;gap:6px;width:28px;cursor:pointer;z-index:1001}.burger span{display:block;height:1.5px;background:var(--black);transition:all .4s var(--ease);transform-origin:center}.burger.open span:first-child{transform:translateY(7.5px) rotate(45deg)}.burger.open span:nth-child(2){opacity:0}.burger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}.mobile-menu{position:fixed;inset:0;z-index:999;background:hsla(30,33%,94%,.95);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;opacity:0;pointer-events:none;transition:opacity .5s var(--ease)}.mobile-menu.open{opacity:1;pointer-events:all}.mobile-menu a{font-family:var(--font-display);font-size:28px;color:var(--black);transition:opacity .3s var(--ease)}.mobile-menu a:hover{opacity:.6}@media (max-width:768px){.nav{padding:20px 24px}.nav.scrolled{padding:16px 24px}.nav-links{display:none}.burger{display:flex}}.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 32px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;border-radius:var(--radius-btn);transition:all .4s var(--ease);white-space:nowrap}.btn-primary{background:var(--black);color:var(--cream)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(26,26,26,.15)}.btn-outline{background:transparent;color:var(--black);border:1.5px solid var(--black)}.btn-outline:hover{background:var(--black);color:var(--cream);transform:translateY(-2px);box-shadow:0 8px 30px rgba(26,26,26,.15)}.btn-light{background:var(--cream);color:var(--black)}.btn-light:hover{transform:translateY(-2px);box-shadow:0 8px 30px hsla(30,33%,94%,.3)}.btn-full{width:100%}.section-title{text-align:center;margin-bottom:64px}.section-title .label{font-size:11px;text-transform:uppercase;letter-spacing:3px;color:var(--gray-light);margin-bottom:16px;display:block}.section-title h2{font-family:var(--font-display);font-size:clamp(28px,4vw,42px);font-weight:500;margin-bottom:12px}.section-title h2 em{font-style:italic}.section-title .subtitle{font-size:15px;color:var(--gray);max-width:460px;margin:0 auto;line-height:1.7}.footer{background:var(--white);padding:48px;text-align:center;border-top:1px solid var(--gray-border)}.footer-content{max-width:1200px;margin:0 auto}.footer-logo{font-family:var(--font-body);font-size:16px;font-weight:600;letter-spacing:2px;text-transform:lowercase;margin-bottom:24px;display:block}.footer-links{display:flex;justify-content:center;gap:32px;margin-bottom:24px}.footer-link{font-size:13px;color:var(--gray);transition:color .3s var(--ease)}.footer-link:hover{color:var(--black)}.footer-copy{font-size:12px;color:var(--gray-light);margin-top:24px}.social-links{display:flex;gap:20px;align-items:center}.social-links.centered{justify-content:center}.social-link{color:var(--gray);transition:all .3s var(--ease);display:flex}.social-link:hover{color:var(--black);transform:translateY(-2px)}.social-link svg{width:20px;height:20px}.anim-section{opacity:0;transform:translateY(40px);transition:opacity .9s var(--ease),transform .9s var(--ease)}.anim-section.visible{opacity:1;transform:translateY(0)}.project-card{background:var(--white);border-radius:var(--radius-card);overflow:hidden;transition:all .5s var(--ease);cursor:pointer}.project-card:hover{transform:translateY(-6px);box-shadow:0 20px 60px rgba(26,26,26,.08)}.project-card-visual{height:220px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.project-card-mockup{width:75%;height:70%;background:hsla(0,0%,100%,.5);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:12px;border:1px solid hsla(0,0%,100%,.6);display:flex;flex-direction:column;align-items:center;transition:transform .5s var(--ease)}.project-card:hover .project-card-mockup{transform:scale(1.03)}.project-detail-badge,.project-live-badge{z-index:2}.project-card-dots{display:flex;gap:6px;padding:12px 16px;width:100%}.project-card-dots span{width:8px;height:8px;border-radius:50%;background:rgba(26,26,26,.15)}.project-card-mockup-image{flex:1 1;position:relative;width:100%;overflow:hidden;border-radius:0 0 11px 11px}.project-card-mockup-title{flex:1 1;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-style:italic;font-size:16px;color:var(--black);opacity:.7}.project-card-info{padding:24px}.project-card-info h3{font-family:var(--font-display);font-size:20px;margin-bottom:4px}.project-card-info p{font-size:13px;color:var(--gray)}.project-detail-card{background:var(--white);border-radius:var(--radius-card);overflow:hidden;transition:all .5s var(--ease)}.project-detail-card:hover{transform:translateY(-8px);box-shadow:0 24px 60px rgba(26,26,26,.1)}.project-detail-visual{height:240px;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}.project-detail-badge{position:absolute;top:16px;right:16px;border:1px solid hsla(0,0%,100%,.6);padding:6px 16px;border-radius:50px;font-size:11px;font-weight:500;letter-spacing:.5px;color:var(--black)}.project-detail-badge,.project-detail-mockup{background:hsla(0,0%,100%,.5);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.project-detail-mockup{width:70%;height:65%;border-radius:12px;border:1px solid hsla(0,0%,100%,.6);display:flex;flex-direction:column;align-items:center;transition:transform .5s var(--ease)}.project-detail-card:hover .project-detail-mockup{transform:scale(1.05)}.project-detail-dots{display:flex;gap:6px;padding:10px 14px;width:100%}.project-detail-dots span{width:7px;height:7px;border-radius:50%;background:rgba(26,26,26,.15)}.project-detail-mockup-image{flex:1 1;position:relative;width:100%;overflow:hidden;border-radius:0 0 11px 11px}.project-detail-mockup-title{flex:1 1;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-style:italic;font-size:15px;color:var(--black);opacity:.7}.project-detail-info{padding:28px}.project-detail-info h3{font-family:var(--font-display);font-size:22px;margin-bottom:8px}.project-detail-info p{font-size:13px;color:var(--gray);line-height:1.7;margin-bottom:16px}.project-detail-footer{display:flex;flex-direction:column;gap:16px}.project-detail-tags{display:flex;flex-wrap:wrap;gap:8px}.project-detail-tags span{background:var(--cream);padding:6px 14px;border-radius:50px;font-size:11px;font-weight:500;color:var(--gray);letter-spacing:.3px}.project-detail-link{font-size:13px;font-weight:500;color:var(--black);display:inline-flex;align-items:center;gap:4px;border-bottom:1px solid var(--gray-border);padding-bottom:2px;transition:all .3s var(--ease);width:-moz-fit-content;width:fit-content}.project-detail-link:hover{border-color:var(--black);gap:8px}.project-live-badge{position:absolute;bottom:16px;left:16px;background:rgba(26,26,26,.75);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:5px 14px;border-radius:50px;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:1px;color:var(--cream)}.project-detail-card-live{box-shadow:0 4px 24px rgba(26,26,26,.06)}.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:120px 24px 80px;position:relative;overflow:hidden}.hero-label{font-size:11px;text-transform:uppercase;letter-spacing:4px;color:var(--gray-light);margin-bottom:28px}.hero h1{font-family:var(--font-display);font-size:clamp(38px,7vw,78px);font-weight:500;line-height:1.15;max-width:800px;margin-bottom:24px}.hero h1 em{font-style:italic}.hero-subtitle{font-size:clamp(15px,2vw,17px);color:var(--gray);max-width:520px;line-height:1.7;margin-bottom:40px}.hero-buttons{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;margin-bottom:40px}.hero-social{margin-bottom:60px}.scroll-indicator{position:absolute;bottom:40px;display:flex;flex-direction:column;align-items:center;gap:12px}.scroll-indicator span{font-size:10px;text-transform:uppercase;letter-spacing:3px;color:var(--gray-light)}.scroll-indicator .line{width:1px;height:40px;background:var(--gray-border);position:relative;overflow:hidden}.scroll-indicator .line:after{content:"";position:absolute;top:-100%;left:0;width:100%;height:100%;background:var(--black);animation:scrollLine 2s var(--ease) infinite}@keyframes scrollLine{0%{top:-100%}50%{top:0}to{top:100%}}.deco-line{position:absolute;width:1px;background:var(--gray-border);opacity:.4;bottom:0}.deco-line-left{left:8%;height:0;animation:decoGrow 2s var(--ease) .5s forwards}.deco-line-right{right:8%;height:0;animation:decoGrow 2s var(--ease) .8s forwards}@keyframes decoGrow{to{height:30%}}.hero-page{min-height:auto;padding:160px 24px 80px}.section{padding:100px 24px}.section-white{background:var(--white)}.section-cream{background:var(--cream)}.section-black{background:var(--black);color:var(--cream)}.container{max-width:1100px;margin:0 auto}.container-sm{max-width:700px;margin:0 auto}.intro-section{text-align:center;padding:100px 24px}.intro-line{width:60px;height:2px;background:var(--black);margin:0 auto 40px}.intro-text{font-family:var(--font-display);font-size:clamp(22px,3.5vw,36px);font-weight:400;line-height:1.5;max-width:700px;margin:0 auto 20px}.intro-text em{font-style:italic}.intro-subtext{font-size:15px;color:var(--gray);max-width:600px;margin:0 auto;line-height:1.7}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:28px;gap:28px}.projects-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));grid-gap:28px;gap:28px}.cta-section{text-align:center;padding:100px 24px}.cta-label{font-size:11px;text-transform:uppercase;letter-spacing:3px;margin-bottom:20px;display:block}.cta-label,.cta-section.section-black .cta-label{color:var(--gray-light)}.cta-title{font-family:var(--font-display);font-size:clamp(28px,4vw,44px);font-weight:500;margin-bottom:36px}.cta-title em{font-style:italic}.about-hero{display:grid;grid-template-columns:1fr 1fr;grid-gap:60px;gap:60px;align-items:center;padding:160px 24px 80px;max-width:1100px;margin:0 auto}.about-hero-label{font-size:11px;text-transform:uppercase;letter-spacing:3px;color:var(--gray-light);margin-bottom:20px;display:block}.about-hero h1{font-family:var(--font-display);font-size:clamp(30px,4vw,44px);font-weight:500;line-height:1.2;margin-bottom:24px}.about-hero h1 em{font-style:italic}.about-hero-text{font-size:15px;color:var(--gray);line-height:1.8}.about-avatar,.about-hero-visual{display:flex;align-items:center;justify-content:center}.about-avatar{width:100%;max-width:400px;height:400px;background:var(--beige);border-radius:24px;position:relative}.about-avatar-circle{width:120px;height:120px;border-radius:50%;background:hsla(0,0%,100%,.5);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid hsla(0,0%,100%,.6);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:40px;font-weight:500;color:var(--black)}.parcours-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:60px;gap:60px;max-width:900px;margin:0 auto}.parcours-section-header{display:flex;align-items:center;gap:12px;margin-bottom:28px}.parcours-icon{width:28px;height:28px;border-radius:50%;background:#f0ebe5;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}.parcours-section-title{font-family:var(--font-body);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:3px;color:var(--black)}.tl-track{padding-left:28px;border-left:1.5px solid #e8e0d8;display:flex;flex-direction:column;gap:32px}.tl-item,.tl-track{position:relative}.tl-dot{position:absolute;left:-34px;top:4px;width:10px;height:10px;border-radius:50%;background:#c4a882;border:2px solid #f7f3ee}.tl-content{display:flex;flex-direction:column;gap:4px}.tl-date{font-size:11px;color:#b8a89a;text-transform:uppercase;letter-spacing:.5px}.tl-date,.tl-role{font-family:var(--font-body);font-weight:500}.tl-role{font-size:14px;color:#2c2420;line-height:1.5}.tl-place{font-size:12px;color:#8a7e74;line-height:1.6}.tl-badge{display:inline-block;width:-moz-fit-content;width:fit-content;margin-top:4px;font-size:10px;font-weight:500;padding:2px 8px;border-radius:10px;background:#f0ebe5;color:#8a7e74;letter-spacing:.3px}@media (max-width:768px){.parcours-grid{grid-template-columns:1fr;gap:48px}}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:28px;gap:28px}.skill-card{background:hsla(0,0%,100%,.5);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid hsla(0,0%,100%,.6);border-radius:var(--radius-card);padding:36px;transition:all .4s var(--ease)}.skill-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(26,26,26,.06)}.skill-card h3{font-family:var(--font-display);font-size:22px;margin-bottom:20px}.skill-list li{font-size:14px;color:var(--gray);padding:8px 0;display:flex;align-items:center;gap:12px}.skill-dot{width:6px;height:6px;border-radius:50%;background:var(--black);flex-shrink:0}.cv-section{text-align:center;padding:80px 24px}.cv-section p{font-size:16px;color:var(--gray);margin-bottom:28px}.service-card{background:var(--cream);border-radius:var(--radius-card);padding:48px;display:grid;grid-template-columns:1fr 1fr;grid-gap:48px;gap:48px;margin-bottom:28px;transition:all .4s var(--ease)}.service-card:hover{box-shadow:0 16px 40px rgba(26,26,26,.04)}.service-number{font-size:48px;color:var(--beige);display:block}.service-card h3,.service-number{font-family:var(--font-display);font-weight:500;margin-bottom:16px}.service-card h3{font-size:26px}.service-card .service-desc{font-size:14px;color:var(--gray);line-height:1.7}.service-features{display:flex;flex-direction:column;gap:16px}.service-feature{display:flex;align-items:center;gap:14px;font-size:14px}.service-check{width:24px;height:24px;border-radius:50%;background:var(--black);display:flex;align-items:center;justify-content:center;flex-shrink:0}.service-check svg{width:12px;height:12px}.service-price{margin-top:24px;padding-top:24px;border-top:1px solid var(--gray-border);font-family:var(--font-display);font-size:18px;font-weight:500}@media (max-width:768px){.service-card{grid-template-columns:1fr;padding:32px;gap:32px}}.contact-email{font-size:16px;color:var(--gray);margin-bottom:24px}.contact-email a{color:var(--black);border-bottom:1px solid var(--gray-border);transition:border-color .3s var(--ease)}.contact-email a:hover{border-color:var(--black)}.contact-form-wrap{max-width:600px;margin:0 auto;background:hsla(0,0%,100%,.6);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid hsla(0,0%,100%,.6);border-radius:24px;padding:48px}.form-group{margin-bottom:24px}.form-group label{display:block;font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--gray);margin-bottom:10px;font-weight:500}.form-group input,.form-group textarea{width:100%;padding:14px 18px;border:1.5px solid var(--gray-border);border-radius:12px;background:var(--white);font-size:15px;color:var(--black);transition:all .3s var(--ease);outline:none}.form-group input:focus,.form-group textarea:focus{border-color:var(--black);box-shadow:0 0 0 3px rgba(26,26,26,.05)}.form-group textarea{resize:vertical;min-height:120px}.form-success{color:var(--black);background:var(--beige-light)}.form-error,.form-success{text-align:center;padding:14px;font-size:14px;border-radius:12px;margin-bottom:16px}.form-error{color:#8b3a3a;background:#f5e0e0}.footer-top{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;margin-bottom:40px}.footer-brand{display:flex;flex-direction:column;gap:8px}.footer-tagline{font-size:12px;color:var(--gray-light);letter-spacing:.5px}.footer-nav{display:flex;gap:28px;flex-wrap:wrap}.footer-divider{height:1px;background:var(--gray-border);margin-bottom:24px}.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.footer-legal{display:flex;gap:24px}.footer-legal-link{font-size:12px;color:var(--gray-light);transition:color .3s var(--ease)}.footer-legal-link:hover{color:var(--black)}.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:20px 40px;background:hsla(40,60%,99%,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--gray-border);animation:slideUp .5s var(--ease) both}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.cookie-text{font-size:14px;color:var(--gray);line-height:1.6}.cookie-link{color:var(--black);border-bottom:1px solid var(--gray-border);transition:border-color .3s var(--ease)}.cookie-link:hover{border-color:var(--black)}.cookie-btn{padding:10px 24px!important;flex-shrink:0}.legal-page{max-width:700px;margin:0 auto;padding:140px 24px 80px}.legal-page h1{font-family:var(--font-display);font-size:clamp(28px,4vw,42px);font-weight:500;margin-bottom:56px}.legal-section{margin-bottom:40px;padding-bottom:40px;border-bottom:1px solid var(--gray-border)}.legal-section:last-child{border-bottom:none}.legal-section h2{font-family:var(--font-display);font-size:20px;font-weight:500;margin-bottom:16px}.legal-section h3{font-family:var(--font-body);font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--gray);margin:20px 0 8px}.legal-section p{font-size:15px;color:var(--gray);line-height:1.8;margin-bottom:8px}.legal-section a{color:var(--black);border-bottom:1px solid var(--gray-border);transition:border-color .3s var(--ease)}.legal-section a:hover{border-color:var(--black)}.legal-list{list-style:disc;padding-left:20px;margin-top:8px}.legal-list li{font-size:15px;color:var(--gray);line-height:1.8;margin-bottom:4px}.legal-list-ordered{list-style:decimal}.legal-subtitle{font-size:14px;color:var(--gray-light);margin-top:12px;margin-bottom:48px}.service-card-featured{padding:56px}.coming-soon-header{text-align:center;padding:48px 0 32px}.coming-soon-label{font-size:11px;text-transform:uppercase;letter-spacing:3px;color:var(--gray-light);margin-bottom:16px;display:block}.coming-soon-title{font-family:var(--font-display);font-size:clamp(24px,3vw,34px);font-weight:500;color:var(--gray-light)}.coming-soon-title em{font-style:italic}.service-card-faded{background:var(--beige-light);border:1.5px dashed var(--gray-border);cursor:default;position:relative}.service-card-faded:hover{box-shadow:none;transform:none}.service-badge-soon{position:absolute;top:20px;right:20px;background:hsla(0,0%,100%,.5);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid hsla(0,0%,100%,.6);padding:5px 14px;border-radius:50px;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:1px;color:var(--gray-light)}.service-number-faded{color:var(--gray-border)!important}.service-desc-faded,.service-title-faded{color:var(--gray-light)!important}.service-desc-faded{opacity:.8}.service-price-faded{border-top-color:var(--gray-border)!important;color:var(--gray-light)!important}.service-check-faded{background:var(--gray-border)!important}.service-feature-faded{color:var(--gray-light)}.coming-soon-footer{text-align:center;padding:32px 0 8px;display:flex;flex-direction:column;align-items:center;gap:16px}.coming-soon-sub{font-size:14px;color:var(--gray-light)}.footer-legal-sep{color:var(--gray-light);font-size:12px}@media (max-width:768px){.hero h1{font-size:clamp(32px,8vw,50px)}.hero-buttons{flex-direction:column;align-items:center}.about-hero{grid-template-columns:1fr;padding:140px 24px 60px;gap:40px}.about-avatar{height:280px}.timeline-item{grid-template-columns:1fr;gap:12px}.section{padding:60px 24px}.projects-detail-grid,.projects-grid{grid-template-columns:1fr}.contact-form-wrap{padding:32px 24px}.cookie-banner{flex-direction:column;align-items:flex-start;padding:20px 24px}.cookie-btn{width:100%;justify-content:center}.footer-top{flex-direction:column;gap:24px}.footer-bottom{flex-direction:column;align-items:flex-start}.service-card-featured{padding:32px}}