@import "https://fonts.googleapis.com/css2?family=Playwrite+IE&display=swap";@import "https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;900&display=swap";@import "https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;900&display=swap";body{background-color:#fff5e6}h1,h2,h3{letter-spacing:.05em;font-optical-sizing:auto;font-family:sans-serif;font-size:1.5vw;font-style:normal;font-weight:700}body{background-color:#f5f0e8;margin:0;padding:0;font-family:sans-serif}.app{z-index:1;flex-direction:column;align-items:center;width:100vw;min-height:100vh;padding:0;display:flex;position:relative}.profil-wrapper{flex-direction:column;align-items:center;width:50vw;display:flex}.profil-card{background-color:#b0c1b0;border-radius:2vw;flex-direction:column;align-items:center;width:38vw;height:80%;padding-top:0;padding-bottom:0;display:flex;position:relative;overflow:hidden}.bandeau-card{color:#fff;letter-spacing:.1em;text-align:center;background-color:#3d5c3d;border-radius:2vw;justify-content:center;align-items:center;width:100%;max-width:none;height:10vh;margin-bottom:1.25rem;padding:0 1.5rem;font-family:sans-serif;font-size:1.5vw;font-weight:700;display:flex;box-shadow:0 8px 14px -10px #00000073}.bandeau-card p{margin:0;line-height:1.2}.conteneurimg{flex:1;justify-content:center;align-items:flex-end;width:100%;margin-top:auto;display:flex}.photobuste{-o-object-fit:cover;object-fit:cover;width:65%;display:block}.home-downloads{box-sizing:border-box;flex-direction:column;align-items:center;gap:.8rem;width:100%;padding:1rem;display:flex}.home-downloads-row{grid-template-columns:repeat(2,minmax(0,30vw));justify-content:center;gap:.8rem;width:100%;display:grid}.home-download-btn{text-align:center;color:#fff;letter-spacing:.04em;background-color:#3d5c3d;border:2px solid #3d5c3d;border-radius:999px;justify-content:center;align-items:center;width:100%;height:7vh;padding:.6rem 1.1rem;font-family:sans-serif;font-size:.95rem;font-weight:600;text-decoration:none;transition:background-color .2s,color .2s;display:flex}.home-download-btn:hover,.home-download-btn:focus-visible{color:#3d5c3d;background-color:#f5f0e8}.home-download-btn:focus-visible{outline-offset:2px;outline:2px solid #3d5c3d}.nav-links{flex-wrap:wrap;justify-content:center;gap:1.5rem;margin-top:2rem;display:flex}.nav-links a{color:#3d5c3d;font-family:sans-serif;font-size:.95rem;font-weight:600;text-decoration:none}.nav-links a:hover{text-decoration:underline}.site-header{z-index:40;box-sizing:border-box;background:#f5f0e8;width:100%;margin-bottom:.75rem;padding:1rem 1.25rem;position:sticky;top:0}.site-header:after{content:"";pointer-events:none;background:linear-gradient(#f5f0e8,#f5f0e800);height:24px;position:absolute;bottom:-24px;left:0;right:0}.header-inner{grid-template-columns:1fr auto 1fr;align-items:center;width:min(100%,1100px);margin:0 auto;display:grid}.header-side{min-width:48px}.header-name{text-align:center;letter-spacing:.04em;color:#1d1d1d;margin:0;font-family:sans-serif;font-size:clamp(1.3rem,3vw,2rem);font-weight:900}.header-title{line-height:1.05}.header-actions{z-index:30;position:fixed;top:1rem;right:1rem}.menu-toggle{color:#fff;cursor:pointer;background:#3d5c3d;border:0;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:44px;height:44px;display:flex;box-shadow:0 8px 18px -12px #0009}.menu-toggle-line{background-color:currentColor;border-radius:2px;width:20px;height:2px;transition:transform .22s,opacity .18s}.menu-toggle.open .menu-toggle-line:first-child{transform:translateY(7px)rotate(45deg)}.menu-toggle.open .menu-toggle-line:nth-child(2){opacity:0}.menu-toggle.open .menu-toggle-line:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.menu-overlay{opacity:0;visibility:hidden;z-index:24;background:#00000047;transition:opacity .24s;position:fixed;inset:0}.menu-overlay.open{opacity:1;visibility:visible}.side-menu{z-index:26;background:#5c7c5c;flex-direction:column;gap:5vh;width:min(85vw,320px);height:100vh;padding:1.2rem .8rem 1rem;transition:transform .26s;display:flex;position:fixed;top:0;right:0;transform:translate(102%);box-shadow:-16px 0 35px -22px #0009}.side-menu.open{transform:translate(0)}.side-menu-close{color:#fff;cursor:pointer;background:#5c7c5c;border:0;border-radius:8px;align-self:flex-end;width:34px;height:34px;margin-bottom:.6rem;font-size:1rem;line-height:1}.side-menu a{color:#fff;text-align:center;letter-spacing:.3em;background:#3d5c3d;border-radius:2vw;width:88%;margin:0 auto;padding:.8rem .75rem;font-family:sans-serif;font-size:1rem;text-decoration:none;transition:background .2s,color .2s}.side-menu a:hover{color:#000;background:#d1d8cc}@media (width<=600px){.site-header{padding:.8rem}.header-actions{top:.8rem;right:.8rem}.side-menu{width:min(92vw,300px)}}.projets-page{min-height:100vh}.projets-content{width:min(100%,1100px);margin:0 auto;padding:1.25rem}.projets-title{color:#1d1d1d;margin:0 0 1rem}.projets-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem;display:grid}@media (width<=760px){.projets-grid{grid-template-columns:1fr}}.project-card-wrapper{color:inherit;text-decoration:none;display:block}.project-card{background:#b0c1b0;border-radius:2vw;flex-direction:column;gap:.9rem;height:50vh;padding:0;transition:background-color .25s,color .25s;display:flex;overflow:hidden;box-shadow:0 8px 20px -16px #00000080}.project-card-title-banner{color:#fff;background:#3d5c3d;border-radius:2vw;align-items:center;width:100%;height:7vh;padding:0 .8rem;display:flex}.project-card-title{color:#fff;letter-spacing:.06em;margin-left:.4vw;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:1.1rem;font-weight:700}.project-card-summary{color:#000;margin:0;padding:0 1rem;line-height:1.4}.project-card-image-wrap{justify-content:center;height:20vh;padding:0 1rem;display:flex}.project-card-image{-o-object-fit:contain;object-fit:contain;border-radius:.9rem;width:auto;height:100%;display:block}.project-card-stack{flex-wrap:wrap;gap:.45rem;margin:0;padding:0 1rem 1rem;list-style:none;display:flex}.project-card-chip{color:#f5f0e8;letter-spacing:.02em;background:#3d5c3d;border-radius:999px;padding:.3rem .65rem;font-size:.8rem}.cv-container{flex-direction:column;align-items:center;width:min(100%,1100px);padding:2rem;display:flex}.profil-page{flex-direction:column;gap:1.5rem;width:80vw;max-width:1100px;margin:2rem auto;display:flex}.profil-hero-card{background:linear-gradient(#b0c1b0db, #b0c1b0db), var(--profil-hero-bg);background-position:50%;background-repeat:no-repeat;background-size:cover;border-radius:2vw;overflow:hidden;box-shadow:0 8px 20px -16px #00000080}.profil-hero-banner{color:#fff;letter-spacing:.06em;background:#3d5c3d;border-radius:2vw;align-items:center;min-height:7vh;padding:0 1.2rem;font-family:sans-serif;font-size:1.1rem;font-weight:700;display:flex}.profil-hero-body{grid-template-columns:minmax(190px,280px) minmax(260px,420px);justify-content:center;align-items:center;gap:.8rem;padding:1.2rem 1.2rem 0;display:grid;position:relative}.profil-hero-photo{-o-object-fit:cover;object-fit:cover;z-index:2;border-radius:1.2vw;align-self:end;width:100%;max-width:320px;display:block;position:relative}.profil-hero-text{z-index:2;justify-content:center;width:100%;padding-bottom:1.2rem;display:flex;position:relative}.profil-mini-banners{flex-direction:column;align-items:center;gap:.6rem;margin-left:clamp(.4rem,2vw,1.6rem);display:flex}.profil-mini-banner{color:#fff;text-align:center;letter-spacing:.03em;background:#3d5c3d;border-radius:999px;padding:.45rem 1rem;font-family:sans-serif;font-weight:700;line-height:1.35;box-shadow:0 8px 16px -14px #000000b3}.profil-mini-banner-name{font-size:clamp(1rem,1.2vw,1.25rem)}.profil-mini-banner-role{color:#1f1f1f;background:#f5f0e8;font-size:.95rem}.profil-cards{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;display:grid}.profil-info-card{background:#b0c1b0;border-radius:2vw;overflow:hidden;box-shadow:0 8px 20px -16px #00000080}.profil-info-banner{color:#fff;letter-spacing:.06em;background:#3d5c3d;border-radius:2vw;align-items:center;min-height:7vh;padding:0 1rem;font-family:sans-serif;font-weight:700;display:flex}.profil-info-card p{color:#111;text-align:justify;margin:0;padding:1rem;font-family:sans-serif;font-weight:700;line-height:1.5}@media (width<=960px){.profil-page{width:92vw}.profil-hero-body{grid-template-columns:1fr}.profil-hero-photo{justify-self:center;max-width:260px}.profil-hero-text{padding-bottom:.6rem}.profil-mini-banners{align-items:center;margin-left:0}.profil-mini-banner{text-align:center}.profil-cards{grid-template-columns:1fr}}.cv-container{flex-direction:column;align-items:center;width:min(100%,1100px);margin:0 auto;padding:2rem;display:flex}.cv-frame{border-radius:2vw;width:100%;max-width:900px;overflow:hidden;box-shadow:0 4px 24px #00000040}.cv-banner{text-align:center;background-color:#3d5c3d;padding:1rem 2rem}.cv-banner h1{letter-spacing:.1em;color:#fff;padding:0 1.5rem;font-family:sans-serif;font-size:1.5vw;font-weight:700}.cv-viewer{aspect-ratio:210/297;border:none;width:100%;height:auto;display:block}.projet-page{box-sizing:border-box;flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:calc(100vh - 80px);padding:2rem 1rem;display:flex}.projet-main{box-sizing:border-box;background:#b0c1b0;border-radius:2vw;flex-direction:column;justify-content:space-between;align-items:center;gap:.5rem;width:min(900px,92vw);height:70vh;padding:0 1.25rem 1.5rem;display:flex}.projet-title-banner{background:#3d5c3d;border-radius:2vw;justify-content:center;align-items:center;width:calc(100% + 2.5rem);margin:0 -1.25rem;padding:1rem;display:flex}.projet-title-banner h1{color:#fff;text-align:center;margin:0;font-size:clamp(1.2rem,2.5vw,2rem)}.projet-back-link{color:#3d5c3d;font-weight:700;text-decoration:none}.projet-back-link:hover{text-decoration:underline}.projet-image{-o-object-fit:contain;object-fit:contain;border-radius:2vw;width:90%;max-height:40vh}.projet-description{text-align:center;max-width:70ch;margin:0}.projet-stack{flex-wrap:wrap;justify-content:center;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.projet-stack-item{color:#f5f0e8;background:#3d5c3d;border-radius:999px;padding:.3rem .65rem;font-size:.8rem}.projet-actions{justify-content:center;gap:1rem;margin-top:1rem;display:flex}.projet-download-link{color:#fff;background:#3d5c3d;border-radius:999px;padding:.6rem 1rem;font-weight:600;text-decoration:none}.projet-download-link:hover{opacity:.9}.contact-container{width:80vw;max-width:1100px;margin:2rem auto;padding:0 1rem;font-family:sans-serif}.contact-card{background-color:#b0c1b0;border-radius:2vw;padding:2rem;overflow:hidden}.contact-card-banner{letter-spacing:.1em;color:#fff;background-color:#3d5c3d;border-radius:2vw;justify-content:center;align-items:center;height:10vh;margin:-2rem -2rem 1.5rem;font-family:sans-serif;font-size:1.5vw;font-weight:700;display:flex}.contact-container h1{margin-bottom:1.5rem}.contact-form{flex-direction:column;gap:1.25rem;display:flex}.contact-field{flex-direction:column;gap:.4rem;display:flex}.contact-field label{font-weight:600}.contact-field input,.contact-field textarea{resize:vertical;border:1px solid #ccc;border-radius:6px;outline:none;padding:.6rem .8rem;font-family:inherit;font-size:1rem;transition:border-color .2s}.contact-field input:focus,.contact-field textarea:focus{border-color:#555}.contact-submit{color:#fff;cursor:pointer;background-color:#222;border:none;border-radius:6px;align-self:flex-start;padding:.6rem 1.6rem;font-size:1rem;transition:background-color .2s}.contact-submit:hover{background-color:#444}.contact-success{color:green;font-size:1.1rem}
