@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600&family=Italiana&display=swap');

:root{--paper:#e9e1d3;--cream:#f4eee4;--ink:#20231f;--forest:#17382d;--moss:#70816b;--clay:#a77e6f;--line:rgba(32,35,31,.22);--header:78px}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--paper);color:var(--ink);font-family:"DM Sans",sans-serif;overflow-x:hidden}a{color:inherit}img{display:block;width:100%}
.grain{position:fixed;inset:0;z-index:90;pointer-events:none;opacity:.09;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.4'/%3E%3C/svg%3E")}
.cursor-dot{position:fixed;z-index:95;width:12px;height:12px;border:1px solid var(--ink);border-radius:50%;pointer-events:none;transform:translate(-50%,-50%);transition:width .25s,height .25s,background .25s;mix-blend-mode:difference}.cursor-dot.active{width:42px;height:42px;background:#fff}
.page-loader{position:fixed;inset:0;z-index:200;background:var(--forest);color:var(--cream);display:grid;place-items:center;overflow:hidden;transition:clip-path 1s cubic-bezier(.77,0,.18,1);clip-path:inset(0 0 0 0)}
.page-loader.loaded{clip-path:inset(0 0 100% 0);pointer-events:none}.page-loader.leaving{clip-path:inset(0 0 0 0)}
.page-loader img{position:absolute;bottom:-6vh;width:min(35vw,430px);height:78vh;object-fit:contain;object-position:bottom;filter:drop-shadow(0 20px 40px rgba(0,0,0,.2));animation:loaderFace 1.5s cubic-bezier(.2,.7,.2,1) both}
.loader-name{position:absolute;top:17vh;left:7vw;font:400 clamp(54px,9vw,140px)/.82 "Italiana",serif;display:flex;flex-direction:column}.loader-name em{margin-left:11vw;color:var(--paper)}.loader-orbit{position:absolute;width:48vw;height:48vw;border:1px solid rgba(244,238,228,.25);border-radius:50%;animation:orbit 8s linear infinite}.loader-progress{position:absolute;left:7vw;right:7vw;bottom:7vh;height:1px;background:rgba(255,255,255,.25)}.loader-progress i{display:block;height:100%;background:var(--cream);animation:loadbar 1.25s ease both}
.page-wipe{position:fixed;inset:0;z-index:150;background:var(--clay);transform:translateY(100%);pointer-events:none}.page-wipe.flash{animation:wipeFlash .8s cubic-bezier(.77,0,.18,1)}
@keyframes loadbar{from{width:0}to{width:100%}}@keyframes loaderFace{from{transform:translateY(18%);opacity:0}to{transform:none;opacity:1}}@keyframes orbit{to{transform:rotate(360deg)}}@keyframes wipeFlash{0%{transform:translateY(100%)}50%{transform:translateY(0)}100%{transform:translateY(-100%)}}

.site-header{position:fixed;z-index:100;inset:0 0 auto;height:var(--header);padding:12px 3vw;display:flex;justify-content:space-between;align-items:center;background:rgba(233,225,211,.84);backdrop-filter:blur(14px);border-bottom:1px solid rgba(32,35,31,.12)}
.brand-mark{display:block;width:48px;height:48px;color:var(--forest);text-decoration:none;flex:0 0 auto;transition:transform .4s ease}.brand-mark svg{display:block;width:100%;height:100%;fill:currentColor}.brand-mark:hover{transform:rotate(8deg) scale(1.07)}.site-header nav{display:flex;align-items:center;gap:clamp(14px,2.6vw,42px)}.site-header nav a{position:relative;font-size:11px;letter-spacing:.13em;text-transform:uppercase;text-decoration:none;white-space:nowrap}.site-header nav a::after{content:"";position:absolute;left:0;bottom:-7px;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .35s}.site-header nav a:hover::after,.site-header nav a.active::after{transform:scaleX(1);transform-origin:left}
.eyebrow{margin:0 0 22px;font-size:10px;font-weight:600;letter-spacing:.19em;text-transform:uppercase}h1,h2{margin:0;font:400 clamp(60px,8vw,120px)/.88 "Italiana",serif;letter-spacing:-.035em}h1 em,h2 em{color:var(--forest);font-weight:400}.reveal{opacity:0;transform:translateY(45px);transition:opacity .9s ease,transform 1s cubic-bezier(.2,.7,.2,1)}.reveal.visible{opacity:1;transform:none}

.hero{min-height:100svh;padding:calc(var(--header) + 50px) 6vw 40px;display:grid;grid-template-columns:1.15fr .85fr;align-items:center;position:relative;overflow:hidden}.hero-copy{position:relative;z-index:3}.hero h1{font-size:clamp(76px,11.5vw,175px);display:flex;flex-direction:column}.hero h1 em{margin-left:6vw}.intro{max-width:640px;margin:34px 0 0;font-size:clamp(17px,1.8vw,25px);line-height:1.48;font-weight:300}.hero-actions{display:flex;align-items:center;gap:32px;margin-top:38px}.button{display:inline-flex;gap:35px;padding:16px 20px;background:var(--forest);color:var(--cream);font-size:10px;letter-spacing:.14em;text-transform:uppercase;text-decoration:none}.text-link{font-size:12px;text-underline-offset:5px}
.hero-person{height:min(82vh,760px);align-self:end;position:relative;z-index:2}.hero-person img{height:100%;object-fit:contain;object-position:bottom;filter:drop-shadow(20px 30px 30px rgba(32,35,31,.13))}.hero-person p{position:absolute;right:0;bottom:5%;font:18px/1.25 "Italiana",serif;text-align:right}.portrait-word{position:absolute;z-index:-1;font:clamp(50px,7vw,104px) "Italiana",serif;color:rgba(23,56,45,.15)}.portrait-word-one{top:12%;left:-24%}.portrait-word-two{right:-15%;top:42%;writing-mode:vertical-rl}.hero-rings{position:absolute;right:-16vw;top:5vh;width:55vw;height:55vw}.hero-rings i{position:absolute;inset:0;border:1px solid rgba(23,56,45,.14);border-radius:50%;animation:orbit 18s linear infinite}.hero-rings i:nth-child(2){inset:12%;animation-direction:reverse}.hero-rings i:nth-child(3){inset:24%;animation-duration:12s}.scroll-cue{position:absolute;left:3vw;bottom:25px;display:flex;align-items:center;gap:10px;transform:rotate(-90deg);transform-origin:left center;font-size:9px;text-transform:uppercase;letter-spacing:.15em}.scroll-cue i{width:45px;height:1px;background:currentColor}

.manifesto{padding:110px 7vw 130px;background:var(--forest);color:var(--cream);overflow:hidden}.manifesto>p{max-width:1050px;margin:90px 0 0;font:clamp(43px,6.5vw,96px)/1.02 "Italiana",serif}.marquee{margin:0 -7vw;border-block:1px solid rgba(255,255,255,.25);padding:15px 0;overflow:hidden}.marquee div{width:max-content;font-size:12px;letter-spacing:.15em;text-transform:uppercase;animation:marquee 26s linear infinite}@keyframes marquee{to{transform:translateX(-50%)}}

.pathways{padding:130px 7vw}.pathways-intro{display:grid;grid-template-columns:.7fr 1.3fr;margin-bottom:70px}.pathways-intro h2{font-size:clamp(58px,8vw,118px)}.pathway-cards{display:grid;grid-template-columns:1fr 1fr;gap:18px}.pathway-card{min-height:540px;padding:35px;background:var(--forest);color:var(--cream);text-decoration:none;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;position:relative}.pathway-card-light{background:var(--clay);color:var(--ink)}.pathway-card::before{content:"";position:absolute;width:350px;height:350px;border:1px solid currentColor;border-radius:50%;opacity:.18;right:-100px;top:-100px;transition:transform .7s}.pathway-card:hover::before{transform:scale(1.4)}.pathway-card>span{font:82px "Italiana",serif;opacity:.25}.pathway-card p{font-size:10px;letter-spacing:.16em;text-transform:uppercase}.pathway-card h3{margin:8px 0 0;font:clamp(43px,5vw,72px)/.95 "Italiana",serif}.pathway-card b{font-size:11px;letter-spacing:.13em;text-transform:uppercase;font-weight:500}

.travel-scroll{height:900vh;background:#babba7;position:relative}.travel-sticky{position:sticky;top:0;height:100vh;overflow:hidden;display:flex;align-items:center;background:#babba7}.travel-intro{position:relative;z-index:4;flex:0 0 min(42vw,590px);height:100%;padding:calc(var(--header) + 25px) 5vw 20px;display:flex;flex-direction:column;justify-content:center;background:#babba7;box-shadow:32px 0 45px #babba7}.travel-intro h2{font-size:clamp(54px,7vw,100px)}.travel-intro>p:not(.eyebrow){max-width:330px;line-height:1.6;margin-top:35px}.travel-progress{width:100%;height:1px;background:rgba(32,35,31,.25);margin-top:45px}.travel-progress i{display:block;width:0;height:100%;background:var(--forest)}
.travel-window{position:relative;z-index:1;height:100%;flex:1;min-width:0;overflow:hidden;background:#babba7}.travel-track{position:absolute;left:0;top:14vh;height:72vh;display:flex;align-items:center;gap:18px;will-change:transform;padding-right:8vw}.travel-card{flex:0 0 31vw;height:58vh;position:relative;overflow:hidden;background:var(--forest)}.travel-card.tall{height:72vh}.travel-card.short{height:48vh}.travel-card.wide{flex-basis:47vw}.travel-card img{height:100%;object-fit:cover;filter:saturate(.72) sepia(.08);transition:transform .8s,filter .8s}.travel-card:hover img{transform:scale(1.045);filter:saturate(1)}.travel-card::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 45%,rgba(10,20,16,.76))}.travel-card>div{position:absolute;z-index:2;left:25px;right:25px;bottom:24px;color:white}.travel-card span{font-size:9px;letter-spacing:.16em;text-transform:uppercase}.travel-card h3{font:clamp(32px,4vw,55px) "Italiana",serif;margin:5px 0 0}.travel-card p{margin:4px 0 0;font-size:12px}.coronation{outline:1px solid rgba(255,255,255,.6);outline-offset:-10px}.travel-end{flex:0 0 46vw;padding:50px}.travel-end p{font:clamp(42px,6vw,84px)/1 "Italiana",serif}.travel-end em{color:var(--forest)}.travel-end span{font-size:11px;letter-spacing:.15em;text-transform:uppercase}

.passions{padding:130px 7vw;background:var(--cream)}.section-heading{display:grid;grid-template-columns:.65fr 1.35fr;padding-bottom:65px;border-bottom:1px solid var(--line);margin-bottom:65px}.section-heading h2{font-size:clamp(55px,7.5vw,112px)}.passion-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:8vw}.passion-feature{min-height:590px;padding:35px;background:var(--clay);display:flex;flex-direction:column;justify-content:flex-end;position:relative}.passion-feature>span{position:absolute;top:32px;font-size:10px;text-transform:uppercase;letter-spacing:.15em}.passion-feature h3{margin:0;font:clamp(50px,6vw,82px)/.95 "Italiana",serif}.passion-feature p{max-width:400px;line-height:1.6}.passion-feature i{position:absolute;right:32px;top:28px;font:44px "Italiana",serif}.passion-list article{display:grid;grid-template-columns:40px 170px 1fr;gap:20px;align-items:baseline;padding:28px 0;border-bottom:1px solid var(--line)}.passion-list span{font-size:10px}.passion-list h3{margin:0;font:30px "Italiana",serif}.passion-list p{margin:0;line-height:1.55;font-weight:300}
.music-section{margin:120px -7vw -130px;padding:110px 7vw 130px;background:var(--forest);color:var(--cream)}.music-heading{display:grid;grid-template-columns:.5fr 1.1fr .65fr;gap:50px;align-items:end;margin-bottom:70px}.music-heading>span{align-self:start;font-size:10px;letter-spacing:.16em;text-transform:uppercase}.music-heading h3{margin:0;font:clamp(50px,7vw,100px)/.9 "Italiana",serif}.music-heading h3 em{color:var(--clay);font-weight:400}.music-heading p{line-height:1.65;font-weight:300}.album-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:38px 14px}.album-card{text-decoration:none;position:relative}.album-card img{aspect-ratio:1;object-fit:cover;filter:saturate(.75);transition:transform .55s cubic-bezier(.2,.7,.2,1),filter .55s}.album-card:hover img{transform:translateY(-12px) rotate(-1.5deg);filter:saturate(1)}.album-card span{display:block;margin-top:15px;font-size:9px;opacity:.55}.album-card h4{margin:7px 0 3px;font:22px/1.05 "Italiana",serif}.album-card p{margin:0;font-size:11px;opacity:.7}

.contact{min-height:100vh;padding:130px 7vw 70px;background:var(--moss);position:relative;display:flex;align-items:center;overflow:hidden}.contact-content{position:relative;z-index:2}.contact h2{font-size:clamp(72px,11vw,160px)}.contact h2 em{color:var(--cream)}.contact-links{display:flex;flex-wrap:wrap;gap:30px 60px;margin-top:60px}.contact-links a{font-size:clamp(18px,2.2vw,31px);text-underline-offset:8px}.contact-face{position:absolute;right:-3vw;bottom:-18%;width:min(42vw,600px);opacity:.25;filter:grayscale(1)}
footer{padding:32px 3vw;display:flex;align-items:center;gap:35px;font-size:10px;text-transform:uppercase;letter-spacing:.1em}footer p{margin-right:auto}footer a{text-underline-offset:5px}.contact-tab{position:fixed;z-index:110;right:0;top:50%;transform:translateY(-50%);width:44px;height:154px;background:var(--forest);color:var(--cream);display:flex;align-items:center;justify-content:center;text-decoration:none;box-shadow:0 8px 28px rgba(23,56,45,.18)}.contact-tab span{writing-mode:vertical-rl;transform:rotate(180deg);font-size:9px;letter-spacing:.15em;text-transform:uppercase}.contact-tab i{position:absolute;bottom:10px;font-style:normal;font-size:14px}.contact-tab:hover{background:var(--clay);color:var(--ink)}

.story-page{padding-top:var(--header)}.story-hero{min-height:calc(100vh - var(--header));padding:70px 7vw 0;display:grid;grid-template-columns:1fr .9fr;align-items:center;overflow:hidden;background:var(--paper)}.story-hero h1{font-size:clamp(70px,9vw,140px)}.story-hero>div:first-child>p:last-child{max-width:550px;margin-top:34px;font-size:19px;line-height:1.65}.story-hero-collage{height:100%;position:relative;align-self:end}.story-hero-collage>img:first-child{position:absolute;right:0;top:10%;width:82%;height:65%;object-fit:cover;filter:saturate(.72)}.story-hero-collage>img:last-child{position:absolute;right:7%;bottom:-2%;width:66%;height:82%;object-fit:contain;object-position:bottom;filter:drop-shadow(20px 20px 25px rgba(0,0,0,.17))}.academic-hero{background:var(--clay)}.story-chapters{background:var(--paper)}.story-chapter{min-height:100vh;padding:10vh 7vw;display:grid;grid-template-columns:1fr .85fr;gap:8vw;align-items:center;border-top:1px solid var(--line);overflow:hidden}.story-chapter.reverse{grid-template-columns:.85fr 1fr}.story-chapter.reverse .story-visual{order:2}.story-chapter.clay{background:var(--clay)}.story-chapter.forest{background:var(--forest);color:var(--cream)}.story-visual{position:relative;height:72vh;overflow:hidden}.story-visual>img{height:115%;object-fit:cover;filter:saturate(.68) sepia(.08);will-change:transform}.story-visual>span{position:absolute;left:20px;bottom:18px;background:var(--cream);color:var(--ink);padding:9px 12px;font-size:9px;letter-spacing:.14em;text-transform:uppercase}.story-copy time{font-size:10px;letter-spacing:.15em;text-transform:uppercase}.story-copy h2{margin-top:18px;font-size:clamp(55px,7.5vw,110px)}.story-copy h3{margin:25px 0 0;font:clamp(20px,2vw,28px)/1.2 "Italiana",serif}.story-copy p{max-width:620px;line-height:1.75;font-weight:300}.story-copy ul{display:flex;flex-wrap:wrap;gap:9px;padding:0;margin:30px 0 0;list-style:none}.story-copy li{border:1px solid currentColor;border-radius:999px;padding:9px 13px;font-size:9px;letter-spacing:.12em;text-transform:uppercase}.skill-visual{background:var(--forest);display:grid;place-items:center}.skill-orbit{position:relative;width:min(30vw,430px);height:min(30vw,430px);border:1px solid rgba(255,255,255,.3);border-radius:50%;animation:orbit 18s linear infinite}.skill-orbit::before,.skill-orbit::after{content:"";position:absolute;border:1px solid rgba(255,255,255,.18);border-radius:50%;inset:14%}.skill-orbit::after{inset:30%}.skill-orbit span{position:absolute;color:var(--cream);font:clamp(15px,2vw,27px) "Italiana",serif;animation:orbit 18s linear infinite reverse}.skill-orbit span:nth-child(1){top:8%;left:16%}.skill-orbit span:nth-child(2){top:25%;right:4%}.skill-orbit span:nth-child(3){bottom:12%;right:18%}.skill-orbit span:nth-child(4){bottom:18%;left:3%}.skill-orbit span:nth-child(5){top:43%;left:30%}

@media(max-width:900px){:root{--header:72px}.cursor-dot{display:none}.site-header{padding-inline:18px;gap:20px}.site-header nav{overflow-x:auto;gap:22px;padding:20px 2px;scrollbar-width:none}.site-header nav::-webkit-scrollbar{display:none}.site-header nav a{font-size:9px}.brand-mark{width:44px;height:44px}.hero{grid-template-columns:1fr;padding:calc(var(--header) + 45px) 6vw 0;min-height:auto}.hero-person{height:63vh;margin-top:15px}.hero-person p{display:none}.hero h1 em{margin-left:5vw}.pathways-intro,.section-heading{grid-template-columns:1fr;gap:25px}.pathway-cards{grid-template-columns:1fr}.pathway-card{min-height:430px}.travel-scroll{height:850vh}.travel-intro{flex-basis:46vw;padding-inline:4vw}.travel-track{height:68vh}.travel-card{flex-basis:65vw}.travel-card.wide{flex-basis:82vw}.travel-end{flex-basis:75vw}.passion-grid{grid-template-columns:1fr}.music-heading{grid-template-columns:1fr;gap:22px}.album-grid{grid-template-columns:repeat(2,1fr);gap:35px 14px}.story-hero{grid-template-columns:1fr;min-height:110vh;padding-top:70px}.story-hero-collage{min-height:55vh}.story-chapter,.story-chapter.reverse{grid-template-columns:1fr;gap:45px;padding-block:75px}.story-chapter.reverse .story-visual{order:0}.story-visual{height:60vh}.skill-orbit{width:60vw;height:60vw}}
@media(max-width:600px){.site-header{align-items:center;padding-inline:12px;gap:9px}.site-header .brand-mark{width:38px;height:38px}.site-header nav{width:calc(100% - 47px);justify-content:space-between;gap:6px;padding-block:20px}.site-header nav a{font-size:6.8px;letter-spacing:.055em}.hero{padding-inline:5vw}.hero h1{font-size:21vw}.intro{font-size:16px}.hero-actions{align-items:flex-start;flex-direction:column;gap:20px}.hero-person{height:55vh}.portrait-word{font-size:17vw}.manifesto,.pathways,.passions{padding-inline:6vw}.manifesto>p{font-size:12vw}.pathway-card{min-height:390px;padding:26px}.travel-scroll{height:780vh}.travel-intro{flex-basis:46vw;padding-inline:4vw}.travel-intro h2{font-size:10vw}.travel-intro>p:not(.eyebrow){font-size:11px}.travel-card{flex-basis:78vw;height:52vh}.travel-card.wide{flex-basis:88vw}.travel-card.tall{height:63vh}.travel-end{flex-basis:86vw;padding:30px}.passion-list article{grid-template-columns:30px 1fr}.passion-list p{grid-column:2}.music-section{margin-inline:-6vw}.album-grid{grid-template-columns:1fr 1fr}.album-card h4{font-size:18px}.contact{padding-inline:6vw}.contact-links{flex-direction:column}.contact-face{width:85vw;right:-25vw}.contact-tab{width:34px;height:132px}.loader-name{top:13vh}.page-loader img{width:78vw;height:72vh}.loader-orbit{width:90vw;height:90vw}.story-hero{padding-inline:6vw}.story-hero h1{font-size:17vw}.story-hero-collage>img:first-child{width:95%}.story-hero-collage>img:last-child{width:82%}.story-chapter{padding-inline:6vw}.story-visual{height:52vh}.story-copy h2{font-size:15vw}.skill-orbit{width:75vw;height:75vw}footer{align-items:flex-start;flex-wrap:wrap}}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*::before,*::after{animation:none!important;transition:none!important}.page-loader{display:none}.reveal{opacity:1;transform:none}}

/* Carnet en deux temps : introduction, puis galerie argentique */
.travel-sticky{display:block;position:sticky;top:0;height:100vh;overflow:hidden;background:#babba7}
.travel-intro{position:absolute;z-index:4;inset:0;max-width:none;height:100%;padding:calc(var(--header) + 25px) 7vw 20px;display:flex;flex-direction:column;justify-content:center;background:#babba7;box-shadow:none;will-change:opacity,transform}
.travel-intro h2{max-width:850px;font-size:clamp(68px,10vw,150px)}
.travel-intro>p:not(.eyebrow){max-width:420px}
.travel-progress{width:min(420px,70vw)}
.travel-window{position:absolute;z-index:2;inset:0;height:100%;overflow:hidden;background:#babba7;opacity:0;will-change:opacity}
.travel-track{position:absolute;left:7vw;top:15vh;height:70vh;display:flex;align-items:center;gap:22px;padding-right:10vw}
.travel-card,.travel-card.tall,.travel-card.short,.travel-card.wide{flex:0 0 min(37vw,500px);width:min(37vw,500px);height:70vh;aspect-ratio:4/5;border:8px solid rgba(244,238,228,.38);box-shadow:0 18px 45px rgba(32,35,31,.13)}
.travel-card img{filter:sepia(.22) saturate(.68) contrast(1.08) brightness(.94)}
.travel-card:hover img{filter:sepia(.12) saturate(.85) contrast(1.05)}
.travel-card::before{content:"";position:absolute;z-index:1;inset:0;pointer-events:none;opacity:.18;mix-blend-mode:soft-light;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='f'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23f)' opacity='.55'/%3E%3C/svg%3E")}
.coronation{outline-offset:-15px}
.story-hero-collage>img:first-child{filter:sepia(.18) saturate(.7) contrast(1.06);border:8px solid rgba(244,238,228,.35)}
.passions>.travel-scroll{margin:120px -7vw 0}
.passions>.music-section{margin-top:0}

/* Photo de course, découpée comme un tirage argentique */
.passion-feature{isolation:isolate}
.passion-feature::before{content:"";position:absolute;z-index:0;right:6%;top:6%;width:55%;height:68%;background:rgba(244,238,228,.36);border:7px solid rgba(244,238,228,.48);box-shadow:0 20px 36px rgba(32,35,31,.16);transform:rotate(5deg)}
.passion-feature::after{content:"";position:absolute;z-index:2;inset:0;pointer-events:none;opacity:.17;mix-blend-mode:soft-light;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='sportgrain'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.82' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23sportgrain)' opacity='.58'/%3E%3C/svg%3E")}
.running-cutout{position:absolute;z-index:1;right:1%;top:-6%;width:62%;height:76%;object-fit:contain;object-position:center bottom;filter:grayscale(.7) sepia(.18) contrast(1.08) saturate(.72) drop-shadow(14px 18px 16px rgba(32,35,31,.24));transform:rotate(2.5deg);transition:filter .6s,transform .7s cubic-bezier(.2,.7,.2,1)}
.passion-feature:hover .running-cutout{filter:grayscale(.2) sepia(.08) contrast(1.04) saturate(.9) drop-shadow(18px 22px 20px rgba(32,35,31,.22));transform:rotate(0) translateY(-7px)}
.passion-feature>span,.passion-feature h3,.passion-feature p,.passion-feature i{z-index:3}
.passion-feature h3,.passion-feature p{position:relative;width:62%}

@media(max-width:900px){
  .travel-intro{padding-inline:6vw}
  .travel-intro h2{font-size:clamp(60px,13vw,105px)}
  .travel-track{left:6vw}
  .travel-card,.travel-card.tall,.travel-card.short,.travel-card.wide{flex-basis:54vw;width:54vw;height:70vh}
}
@media(max-width:600px){
  .travel-intro{padding-inline:7vw}
  .travel-intro h2{font-size:17vw}
  .travel-intro>p:not(.eyebrow){font-size:13px}
  .travel-track{left:7vw;top:16vh;height:68vh}
  .travel-card,.travel-card.tall,.travel-card.short,.travel-card.wide{flex-basis:74vw;width:74vw;height:68vh}
  .passions>.travel-scroll{margin-inline:-6vw}
  .passion-feature{min-height:610px}
  .passion-feature::before{right:0;top:8%;width:68%;height:64%}
  .running-cutout{right:-7%;top:-2%;width:76%;height:72%}
  .passion-feature h3,.passion-feature p{width:78%}
}

/* Entrée bilingue et changement de langue */
.language-page{min-height:100vh;background:var(--forest);color:var(--cream);overflow:hidden}
.language-gateway{position:relative;min-height:100svh;padding:7vh 7vw;display:grid;grid-template-columns:1.08fr .92fr;align-items:center;isolation:isolate}
.language-logo{position:absolute;z-index:4;left:7vw;top:6vh;color:var(--cream)}
.language-intro{position:relative;z-index:3}
.language-intro h1{font-size:clamp(78px,11vw,170px);color:var(--cream)}
.language-intro h1 em{display:inline-block;margin-left:7vw;color:var(--clay)}
.language-intro>p:last-child{margin:40px 0 0;font-size:16px;line-height:1.7;letter-spacing:.04em}
.language-intro>p:last-child span{color:rgba(244,238,228,.62)}
.language-choices{position:relative;z-index:5;display:grid;gap:12px;width:min(100%,520px);justify-self:end}
.language-choices a{min-height:190px;padding:28px 30px;border:1px solid rgba(244,238,228,.34);color:var(--cream);text-decoration:none;display:grid;grid-template-columns:auto 1fr;grid-template-rows:1fr auto;gap:10px 24px;align-items:end;transition:background .4s,color .4s,transform .4s}
.language-choices a:hover{background:var(--paper);color:var(--forest);transform:translateX(-12px)}
.language-choices span{align-self:start;font-size:10px;letter-spacing:.16em}
.language-choices strong{font:clamp(44px,5vw,74px)/.9 "Italiana",serif;font-weight:400}
.language-choices small{grid-column:2;font-size:9px;letter-spacing:.14em;text-transform:uppercase}
.language-portrait{position:absolute;z-index:1;left:42%;bottom:-15%;width:min(39vw,580px);opacity:.13;filter:grayscale(1)}
.language-orbit{position:absolute;z-index:0;left:-15vw;bottom:-32vw;width:65vw;height:65vw}
.language-orbit i{position:absolute;inset:0;border:1px solid rgba(244,238,228,.12);border-radius:50%;animation:orbit 20s linear infinite}
.language-orbit i:nth-child(2){inset:16%;animation-direction:reverse}.language-orbit i:nth-child(3){inset:32%;animation-duration:13s}
.language-switch{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;border:1px solid currentColor;border-radius:50%;font-size:9px;letter-spacing:.1em;text-decoration:none;transition:background .3s,color .3s}
.language-switch:hover{background:var(--forest);color:var(--cream)}
.inline-language{margin-left:18px;vertical-align:middle}

@media(max-width:800px){
  .language-gateway{padding:15vh 7vw 7vh;grid-template-columns:1fr;align-content:center;gap:45px}
  .language-logo{top:4vh}
  .language-intro h1{font-size:18vw}
  .language-intro>p:last-child{margin-top:25px}
  .language-choices{width:100%;justify-self:stretch;grid-template-columns:1fr 1fr}
  .language-choices a{min-height:155px;padding:22px;display:flex;flex-direction:column;align-items:flex-start;justify-content:space-between}
  .language-choices strong{font-size:9vw}
  .language-portrait{left:auto;right:-12vw;width:75vw}
}
@media(max-width:480px){
  .language-gateway{gap:30px}
  .language-choices{grid-template-columns:1fr}
  .language-choices a{min-height:118px}
  .language-choices strong{font-size:13vw}
}

/* Portrait à gratter */
.scratch-photo{position:relative;width:100%;height:100%;overflow:visible;touch-action:none;user-select:none}
.scratch-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:bottom;filter:grayscale(1) drop-shadow(20px 30px 30px rgba(32,35,31,.13))}
.scratch-photo canvas{position:absolute;inset:0;width:100%;height:100%;cursor:crosshair}
.scratch-hint{position:absolute;z-index:3;left:50%;bottom:14%;transform:translateX(-50%);padding:8px 12px;background:rgba(244,238,228,.88);font-size:8px;letter-spacing:.14em;text-transform:uppercase;white-space:nowrap;pointer-events:none;transition:opacity .4s}
.scratch-photo.scratched .scratch-hint{opacity:0}

/* Téléchargement du mémoire */
.document-download{max-width:520px;margin:30px 0 4px;padding:18px 20px;border:1px solid currentColor;display:flex;justify-content:space-between;align-items:center;gap:25px;text-decoration:none;transition:background .35s,color .35s,transform .35s}
.document-download span{font-size:10px;letter-spacing:.11em;text-transform:uppercase}
.document-download b{font:400 18px "Italiana",serif}
.document-download:hover{background:var(--forest);color:var(--cream);transform:translateY(-3px)}

/* Page compétences RNCP */
.skills-page{background:var(--forest);color:var(--cream)}
.skills-page .site-header{color:var(--ink)}
.skills-main{padding-top:var(--header)}
.skills-hero{min-height:calc(100vh - var(--header));padding:9vh 7vw 7vh;position:relative;display:flex;flex-direction:column;justify-content:center;overflow:hidden}
.skills-hero::before{content:"RNCP";position:absolute;right:-2vw;bottom:-8vh;font:clamp(180px,29vw,430px)/.7 "Italiana",serif;color:rgba(244,238,228,.035)}
.skills-hero h1{position:relative;z-index:1;font-size:clamp(72px,10vw,150px);color:var(--cream)}
.skills-hero h1 em{color:var(--clay)}
.rncp-badge{position:absolute;z-index:2;right:7vw;top:14vh;width:180px;height:180px;border:1px solid rgba(244,238,228,.5);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;animation:orbit 18s linear infinite}
.rncp-badge span{font-size:8px;letter-spacing:.15em;text-transform:uppercase}
.rncp-badge strong{margin-top:8px;font:22px "Italiana",serif}
.skills-grid{padding:0 7vw 130px;display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.skill-card{position:relative;min-height:430px;padding:36px;background:var(--paper);color:var(--ink);overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;transition:transform .55s cubic-bezier(.2,.7,.2,1),background .4s,color .4s}
.skill-card:nth-child(2),.skill-card:nth-child(5){background:var(--clay)}
.skill-card:nth-child(3),.skill-card:nth-child(6){background:var(--moss)}
.skill-card::before{content:"";position:absolute;width:290px;height:290px;border:1px solid currentColor;border-radius:50%;right:-120px;top:-120px;opacity:.16;transition:transform .7s}
.skill-card:hover{transform:translateY(-8px);background:var(--cream)}
.skill-card:hover::before{transform:scale(1.45)}
.skill-card>span{position:absolute;top:32px;left:35px;font-size:10px;letter-spacing:.15em}
.skill-card h2{margin:0;font-size:clamp(49px,6vw,88px);color:inherit;text-transform:uppercase}
.skill-card p{max-width:510px;margin:24px 0 0;line-height:1.65;font-weight:300}
.skills-closing{min-height:75vh;padding:100px 7vw;background:var(--paper);color:var(--ink);display:flex;align-items:center}
.skills-closing p{margin:0;font:clamp(50px,7.5vw,112px)/1 "Italiana",serif}
.skills-closing em{color:var(--forest)}

@media(max-width:900px){
  .skills-grid{grid-template-columns:1fr}
  .rncp-badge{width:135px;height:135px;top:11vh}
  .skill-card{min-height:360px}
}
@media(max-width:600px){
  .site-header nav{gap:4px}
  .site-header nav a{font-size:5.65px;letter-spacing:.035em}
  .scratch-hint{bottom:9%}
  .contact-links a{font-size:20px}
  .document-download{align-items:flex-start;flex-direction:column}
  .skills-hero{padding-inline:6vw;min-height:90vh}
  .skills-hero h1{font-size:17vw}
  .rncp-badge{right:5vw;top:9vh;width:108px;height:108px}
  .rncp-badge strong{font-size:16px}
  .skills-grid{padding-inline:6vw}
  .skill-card{min-height:330px;padding:28px}
  .skill-card h2{font-size:13vw}
  .skills-closing{padding-inline:6vw}
}
