@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500&family=DM+Sans:wght@300;400;500&display=swap";:root{--black: #232322;--ink: #171717;--white: #f5f5f5;--red: #b1103c;--blue: #3c6b9c;--yellow: #f1d84f;font-family:Saira,sans-serif;color:var(--black);background:var(--white);font-synthesis:none;text-rendering:geometricPrecision}html{box-sizing:border-box;width:100%;height:100%;scrollbar-width:none}*,*:before,*:after{box-sizing:inherit}body{width:100%;height:100%;margin:0;color:var(--black);background:var(--white);line-height:1.5;overflow:hidden;-ms-overflow-style:none}::-webkit-scrollbar{display:none;width:0}::selection{background:#232322cc;color:var(--white)}#root,.portfolio-app,.portfolio-app main{min-height:100%}#root{position:relative;z-index:1}.portfolio-app{position:relative;z-index:1;display:flex;flex-direction:column;min-height:100%}.portfolio-app main{flex:1 0 auto}a{color:var(--ink);text-decoration:none}a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{outline:3px solid var(--blue);outline-offset:-3px}button,input,textarea{font:inherit}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}.skip-link{position:fixed;top:16px;left:96px;z-index:8000;padding:10px 14px;background:var(--ink);color:var(--white);font-weight:600;transform:translateY(-140%);transition:transform .2s ease}.skip-link:focus-visible{transform:translateY(0);outline-color:var(--yellow)}section{position:relative;width:100vw;min-height:100vh;overflow:hidden}.wrapper{max-width:1600px;width:100%;margin:0 auto;padding:0 40px 0 120px}#rend{position:fixed;inset:0 auto auto 0;z-index:0;display:block;min-height:100vh;background:var(--white);pointer-events:none}.preloader{position:fixed;top:0;right:0;bottom:0;left:0;z-index:7000;display:flex;align-items:center;justify-content:center;background:var(--white);overflow:hidden}.header-page{position:fixed;top:25px;left:0;z-index:5000;width:100%;height:50px;-webkit-user-select:none;user-select:none;transform:translateZ(0);opacity:1;transition:transform .55s cubic-bezier(.22,1,.36,1),opacity .45s ease;will-change:transform,opacity}.header-page.is-hidden{transform:translate3d(0,-112%,0);opacity:0;pointer-events:none}.header-page nav{display:flex;align-items:center;justify-content:space-between;height:100%}.logo{transition:opacity .3s ease-in-out}.menu{display:flex;align-items:center;justify-content:center;gap:8px;padding:0;border:0;background:transparent;color:var(--black);overflow:hidden;cursor:pointer}.menu svg{width:45px;height:48px;overflow:hidden}.menu-label{width:81px;margin:0;font-size:1.25rem;line-height:1;text-align:left}.menu-modale{position:fixed;top:0;left:80px;z-index:5000;width:0;height:100%;background:var(--white);visibility:hidden;overflow:hidden;transition:width .3s ease-in-out,visibility .3s ease-in-out}.menu-modale-ouvre{width:calc(100% - 80px);visibility:visible}.overlay-content{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding-right:30px;margin-left:auto;white-space:nowrap}.overlay-content .alink:last-child{margin-top:30px;border-top:2px solid var(--red);border-bottom:2px solid var(--red)}.menu-modale a,.menu-language-button{display:block;padding:8px;border:0;background:transparent;color:var(--black);font-size:1.75rem;font-weight:500;text-transform:uppercase;cursor:pointer}.menu-modale a span,.menu-language-button span{position:relative;display:block}.menu-modale a span:before,.menu-modale a span:after,.menu-language-button span:before,.menu-language-button span:after{content:"";position:absolute;top:50%;width:0;height:4px;margin-top:-.5px;background:var(--ink)}.menu-modale a span:before,.menu-language-button span:before{left:-2.5px}.menu-modale a span:after,.menu-language-button span:after{right:2.5px;transition:width .8s cubic-bezier(.22,.61,.36,1)}.menu-modale a span:hover:before,.menu-modale a:focus-visible span:before,.menu-language-button:focus-visible span:before,.menu-language-button span:hover:before{width:100%;transition:width .5s cubic-bezier(.22,.61,.36,1)}.menu-modale a span:hover:after,.menu-modale a:focus-visible span:after,.menu-language-button:focus-visible span:after,.menu-language-button span:hover:after{width:100%;background:transparent;transition:none}.aside-reseausociaux-cv,.aside-reseausociaux-cv-mobile{position:fixed;top:0;z-index:5000;display:flex;flex-direction:column;align-items:center;justify-content:center;width:80px;height:100%;background:#f5f5f5cc;border-right:1px solid var(--black)}.aside-reseausociaux-cv{left:0}.aside-reseausociaux-cv-mobile{left:-80px}.icon-social{display:flex;margin:10px 0}.home{display:flex;flex-direction:column;align-items:center;justify-content:center;perspective:1000px;transform-style:preserve-3d;backface-visibility:hidden}.hero-contenu{display:flex;flex-direction:column;align-items:center;justify-content:space-between;text-align:center;pointer-events:none;transform-origin:center}.hero-contenu h1,.hero-contenu h3{font-family:Playfair Display,serif;font-size:clamp(3.5rem,6vw,5.5rem);transform-origin:center}.hero-contenu h1{margin:0 0 10px;color:var(--black);letter-spacing:14px}.hero-contenu h3{margin:0;font-size:1.75rem;letter-spacing:4px}.voir-projets{position:absolute;bottom:30px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:1.125rem}.section-kicker{padding:8rem 0 0}.section-kicker span{font-size:.76rem;line-height:1;letter-spacing:.25em;font-weight:500;font-family:DM Sans,sans-serif}.section-kicker i{display:block;width:42px;height:1px;background:#1c1c1ce6}.section-heading-row{display:grid;grid-template-columns:1fr .5fr;align-items:flex-end;gap:48px;margin-top:10px;margin-bottom:62px}.section-heading-row p{max-width:430px;margin:18px 0 0 auto;color:#1c1c1c94;font-size:clamp(.98rem,1vw,1.08rem);line-height:1.5}@media(max-width:1100px){.section-heading-row{grid-template-columns:1fr;margin-bottom:40px;gap:0}}@media only screen and (max-width:768px){.skip-link{left:16px}.wrapper{padding:0 25px}.menu-modale{left:0}.menu-modale-ouvre{width:100%}.overlay-content{padding:5rem 0 0 80px}.aside-reseausociaux-cv{opacity:0;visibility:hidden}}.footer-text{font-size:14px;color:#666;text-align:right;padding:20px 0}footer{position:relative;z-index:2;flex-shrink:0}.section-heading-row h2{margin:0;font-family:Playfair Display,serif;font-size:clamp(5.2rem,8vw,5.6rem);line-height:1;font-weight:400;letter-spacing:0}@media only screen and (max-width:600px){.section-heading-row h2{font-size:clamp(3.2rem,8vw,4.6rem)}.menu-modale a,.menu-language-button{padding:4px}.overlay-content .alink:last-child{margin-top:20px;border-top:2px solid var(--red);border-bottom:2px solid var(--red)}}@media only screen and (max-width:500px){.hero-contenu h1,.hero-contenu h3{line-height:1.1}}@media only screen and (max-height:480px){.menu-modale a,.menu-language-button{padding:1px}.overlay-content .alink:last-child{margin-top:10px}}.stack-header{display:flex;align-items:flex-start;justify-content:space-between;gap:48px;margin-bottom:56px}.stack-title{font-family:Playfair Display,serif;font-size:clamp(64px,8vw,96px);font-weight:400;line-height:.92;color:#1a1a1a;margin:0;letter-spacing:-.02em}.stack-description{max-width:360px;font-size:14.5px;color:#666;line-height:1.75;margin:0;padding-top:12px;font-weight:300}.stack-table{border:1px solid #d4d3d0;border-radius:4px;overflow:hidden}.stack-row{display:grid;grid-template-columns:50px 250px 1fr 40px;align-items:center;gap:0;padding:28px 32px;border-bottom:1px solid #d4d3d0;background:transparent;transition:background .3s ease;cursor:default}.stack-row:last-child{border-bottom:none}.row-number{font-size:14px;font-weight:300;color:#666;letter-spacing:.04em;-webkit-user-select:none;user-select:none}.row-label{padding-right:32px}.row-category{font-size:16px;font-weight:600;letter-spacing:.1em;color:#1a1a1a;margin:0 0 4px;text-transform:uppercase}.row-subtitle{font-size:14px;font-weight:300;color:#333;margin:0;letter-spacing:.01em}.tags-wrap{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.tag{display:inline-flex;align-items:center;padding:5px 13px;border:1px solid #c8c7c4;border-radius:3px;font-size:14px;font-weight:400;color:#333;background:transparent;letter-spacing:.01em;transition:border-color .2s ease,background .2s ease;white-space:nowrap}.stack-row:hover .tag{border-color:#aaa}.arrow-btn{display:flex;align-items:center;justify-content:center;color:#1a1a1a;flex-shrink:0}.arrow-btn svg{width:16px;height:16px}@media(max-width:900px){.stack-header{flex-direction:column;gap:24px}.stack-row{grid-template-columns:44px 160px 1fr 32px;padding:22px 20px}.row-divider{margin:0 16px}.row-label{padding-right:20px}}@media(max-width:640px){.stack-row{grid-template-columns:1fr;gap:14px}.row-divider,.row-number{display:none}}.contact-section{font-family:DM Sans,sans-serif}.contact-section .section-heading-row{grid-template-columns:1fr;margin-bottom:20px;gap:10px}.contact-section .section-heading-row p{margin:15px 0 0 10px;max-width:790px;line-height:1.5}.contact-eyebrow{font-size:11px;font-weight:500;letter-spacing:.18em;color:#333;text-transform:uppercase;margin:0 0 8px}.contact-eyebrow-line{width:36px;height:1.5px;background:#222;margin-bottom:36px}.contact-header{display:flex;flex-direction:column;margin-bottom:15px}.contact-title{font-family:Playfair Display,serif;font-size:clamp(64px,8vw,96px);font-weight:400;line-height:.92;color:#1a1a1a;margin:0;letter-spacing:-.02em}.contact-desc{max-width:360px;font-size:14.5px;color:#666;line-height:1.75;margin:0;padding-top:12px;font-weight:300}.contact-form-wrap{border:1px solid #d4d3d0;border-radius:4px;padding:40px 40px 36px;background:transparent;max-width:1000px}.contact-form{display:flex;flex-direction:column;gap:28px}.form-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}.form-row-full{display:grid;grid-template-columns:1fr}.field-group{display:flex;flex-direction:column;gap:7px}.field-label{font-size:14px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:#333}.field-input,.field-textarea{background:transparent;border:1px solid #d4d3d0;border-radius:3px;padding:10px 14px;font-family:DM Sans,sans-serif;font-size:13.5px;font-weight:300;color:#1a1a1a;outline:none;transition:border-color .25s ease,background .25s ease;width:100%;box-sizing:border-box;-webkit-appearance:none}.field-input:focus,.field-textarea:focus{border-color:#888;background:#ffffff80}.field-input::placeholder,.field-textarea::placeholder{color:#ccc;font-weight:300}.field-textarea{resize:none;height:140px;line-height:1.65}.form-footer{display:flex;align-items:center;justify-content:flex-end;gap:18px;padding-top:4px}.submit-btn{display:inline-flex;align-items:center;gap:10px;background:#1a1a1a;color:#f2f1ef;border:none;border-radius:3px;padding:12px 28px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:background .25s ease,transform .2s ease;outline:none}.submit-btn:hover{background:#333;transform:translateY(-1px)}.submit-btn:active{transform:translateY(0)}.submit-btn:disabled{cursor:progress;opacity:.68;transform:none}.submit-btn svg{width:13px;height:13px;transition:transform .25s ease}.submit-btn:hover svg{transform:translate(2px,-2px)}.form-error{max-width:430px;margin:0;color:#9b1d32;font-size:13px;line-height:1.45}.sent-message{text-align:center;padding:48px 0}.sent-message h3{font-family:Playfair Display,serif;font-size:28px;font-weight:400;color:#1a1a1a;margin:0 0 10px}.sent-message p{font-size:14px;color:#888;font-weight:300;margin:0}.contact-info{display:flex;align-items:center;gap:30px;padding:30px 0}.contact-info-item{display:flex;align-items:center;gap:5px;font-size:16px;font-weight:300;color:#333;text-decoration:none;transition:color .2s ease}.contact-info-item:hover{color:#1a1a1a}.contact-info-item svg{width:24px;height:24px;color:#555;flex-shrink:0;transition:color .2s ease}.contact-info-item:hover svg{color:#222}@media(max-width:900px){.contact-header{flex-direction:column;gap:20px}.contact-form-wrap{padding:28px 24px}.form-row{grid-template-columns:1fr}}@media(max-width:500px){.form-footer{align-items:stretch;flex-direction:column}.contact-info{flex-direction:column;align-items:flex-start}}.proj-section{position:relative;font-family:DM Sans,sans-serif;overflow:hidden}.proj-eyebrow{font-size:11px;font-weight:500;letter-spacing:.18em;color:#333;text-transform:uppercase;margin:0 0 8px}.proj-eyebrow-line{width:36px;height:1.5px;background:#222;margin-bottom:36px}.proj-section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:48px;margin-bottom:56px}.proj-section-title{font-family:Playfair Display,serif;font-size:clamp(64px,8vw,96px);font-weight:400;line-height:.92;color:#1a1a1a;margin:0;letter-spacing:-.02em}.proj-section-desc{max-width:360px;font-size:14.5px;color:#666;line-height:1.75;margin:0;padding-top:12px;font-weight:300}.proj-content{display:flex;align-items:flex-start;gap:0;position:relative}.proj-list{flex:1;border:1px solid #d4d3d0;border-radius:4px;overflow:hidden;max-width:50%}.proj-image-panel{width:100%;flex-shrink:0;position:sticky;top:96px;height:calc(100vh - 140px);pointer-events:none;align-self:flex-start;margin-left:48px;max-width:45%}.proj-image-positioner{position:absolute;top:0;left:0;width:100%;will-change:transform}.proj-image-wrap{position:relative;width:100%;aspect-ratio:4/3;border-radius:4px;overflow:hidden;opacity:0;transform:scale(.97)}.proj-image-wrap img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;pointer-events:none;will-change:opacity;z-index:1}.proj-image-mouse-layer{width:100%;will-change:transform}.proj-row.is-active{background:#ffffffb3}.proj-row.is-active .proj-arrow{opacity:1;transform:translate(3px,-3px)}.proj-row.is-active .proj-row-title{color:#111}.proj-row{display:flex;align-items:center;justify-content:space-between;padding:26px 32px;border-bottom:1px solid #d4d3d0;cursor:pointer;text-decoration:none;transition:background .25s ease .06s;position:relative;touch-action:pan-y}.proj-row:last-child{border-bottom:none}.proj-row:hover{background:#ffffff8c}.proj-row:focus-visible{background:#ffffffb3}.proj-row-left{display:flex;flex-direction:column;gap:3px}.proj-row-number{font-size:14px;font-weight:300;color:#666;letter-spacing:.06em;margin-bottom:2px}.proj-row-title{font-size:clamp(24px,2.8vw,34px);font-weight:400;color:#1a1a1a;margin:0;letter-spacing:-.02em;line-height:1.1;transition:color .2s ease}.proj-row:hover .proj-row-title{color:#111}.proj-row-subtitle{font-size:14px;font-weight:300;color:#333;letter-spacing:.01em;margin-top:2px}.proj-arrow{color:#1a1a1a;opacity:0;transform:translate(0);transition:opacity .2s ease .06s,transform .25s ease .06s;flex-shrink:0}.proj-row:hover .proj-arrow{opacity:1;transform:translate(3px,-3px)}.proj-list.is-keyboard-focused .proj-row:hover:not(.is-active):not(:focus-visible){background:transparent}.proj-list.is-keyboard-focused .proj-row:hover:not(.is-active):not(:focus-visible) .proj-row-title{color:#1a1a1a}.proj-list.is-keyboard-focused .proj-row:hover:not(.is-active):not(:focus-visible) .proj-arrow{opacity:0;transform:translate(0)}.proj-arrow svg{width:16px;height:16px}@media(max-width:1280px)and (min-width:900px){.proj-content{gap:28px}.proj-list,.proj-image-panel{max-width:calc(50% - 14px)}.proj-image-panel{margin-left:0}.proj-row{padding:24px}}@media(hover:none)and (pointer:coarse){.proj-row{cursor:default}.proj-row:hover{background:transparent}.proj-row:hover .proj-row-title{color:#1a1a1a}.proj-row:hover .proj-arrow{opacity:0;transform:translate(0)}.proj-row.is-active,.proj-row.is-active:hover{background:#ffffffb3}.proj-row.is-active .proj-row-title,.proj-row.is-active:hover .proj-row-title{color:#111}.proj-row.is-active .proj-arrow,.proj-row.is-active:hover .proj-arrow{opacity:1;transform:translate(3px,-3px)}}@media(max-width:899px){.proj-section-header{flex-direction:column;gap:20px}.proj-row{padding:22px 20px}.proj-list{max-width:100%}.proj-image-panel{display:none}}.exp-list{border:1px solid #d4d3d0;border-radius:4px;overflow:hidden}.exp-row{border-bottom:1px solid #d4d3d0;transition:background .3s ease}.exp-row:last-child{border-bottom:none}.exp-row.is-open{background:#fff9}.exp-header{width:100%;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:28px 32px;background:transparent;border:none;cursor:pointer;text-align:left;transition:background .25s ease}.exp-header:hover{background:#ffffff73}.exp-row.is-open .exp-header{background:transparent}.exp-meta{display:flex;flex-direction:column;gap:3px}.exp-company{font-size:14px;font-weight:400;color:#666;letter-spacing:.03em}.exp-title{font-family:Playfair Display,serif;font-size:clamp(22px,3vw,30px);font-weight:400;color:#1a1a1a;margin:2px 0;letter-spacing:-.01em;line-height:1.15}.exp-period{font-size:14px;font-weight:300;color:#333;letter-spacing:.01em}.exp-toggle{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.toggle-icon{position:relative;width:14px;height:14px}.bar{position:absolute;background:#1a1a1a;border-radius:1px;transition:transform .35s ease,opacity .35s ease}.bar-h{width:14px;height:1.5px;top:50%;left:0;transform:translateY(-50%)}.bar-v{width:1.5px;height:14px;left:50%;top:0;transform:translate(-50%)}.is-open .bar-v{transform:translate(-50%) rotate(90deg);opacity:0}.exp-details{will-change:height}.exp-details-inner{padding:0 32px 28px;border-top:1px solid #d4d3d0}.detail-list{list-style:none;margin:0;padding:20px 0 0;display:flex;flex-direction:column;gap:12px}.detail-item{font-size:16px;font-weight:300;color:#444;padding-left:16px;position:relative;line-height:1.6;letter-spacing:.01em}.detail-item:before{content:"";position:absolute;left:0;top:9px;width:4px;height:1.5px;background:#aaa}@media(max-width:900px){.exp-section-header{flex-direction:column}}@media(max-width:600px){.exp-details-inner{padding:0 15px 25px;border-top:1px solid #d4d3d0}}.about-card{position:relative;display:grid;grid-template-columns:.9fr 1.2fr;align-items:flex-start;overflow:hidden;padding-bottom:5px}.about-content{position:relative;z-index:2;max-width:650px}.about-label{margin:0 0 30px;color:#1c1c1c57;font-size:.86rem;line-height:1;letter-spacing:.15em;font-weight:700}.about-content h3{margin:0;font-family:Playfair Display,serif;font-size:clamp(2.35rem,3vw,4rem);line-height:1;font-weight:400;letter-spacing:-.052em}.about-text{max-width:650px;margin:28px 0 0;color:#1c1c1cb8;font-size:clamp(1rem,1.1vw,1.18rem);line-height:1.85}.about-tags{display:flex;flex-wrap:wrap;gap:14px 16px;margin-top:44px;max-width:620px}.about-tags span{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0 18px;border:1px solid rgba(28,28,28,.17);border-radius:4px;color:#1c1c1cb3;font-size:.92rem;line-height:1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.about-cv-btn{display:inline-flex;align-items:center;gap:10px;padding:13px 24px;border:1px solid #1a1a1a;border-radius:3px;background:transparent;font-family:DM Sans,sans-serif;font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:#1a1a1a;text-decoration:none;cursor:pointer;align-self:flex-start;transition:background .25s ease,color .25s ease,transform .2s ease;position:relative;overflow:hidden}.about-cv-btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#1a1a1a;transform:translateY(100%);transition:transform .3s ease;z-index:0}.about-cv-btn:hover:after{transform:translateY(0)}.about-cv-btn span,.about-cv-btn svg{position:relative;z-index:1;transition:color .3s ease}.about-cv-btn:hover span,.about-cv-btn:hover svg{color:#f2f1ef}.about-cv-btn svg{width:13px;height:13px;color:#1a1a1a}.about-actions{display:flex;gap:24px;flex-wrap:wrap;margin-top:40px}.about-btn{min-width:255px;height:70px;display:inline-flex;align-items:center;justify-content:space-between;gap:26px;padding:0 24px;border-radius:2px;text-decoration:none;font-size:1rem;letter-spacing:.06em;transition:transform .22s ease,background-color .22s ease,color .22s ease,border-color .22s ease}.about-btn:hover{transform:translateY(-2px)}.about-btn-dark{color:#f6f6f6;background:#1e1e1e;border:1px solid #1e1e1e}.about-btn-light{color:#2a2a2a;background:#f2f2f252;border:1px solid rgba(28,28,28,.72)}.about-btn-light:hover{background:#ffffff75}.about-blob-wrap{position:relative;z-index:2;height:640px;min-height:420px;top:-50px}.about-blob-canvas{position:absolute;top:-2%;right:-2%;bottom:-2%;left:-2%}.about-blob-canvas canvas{display:block;width:100%;height:100%}.about-section{position:relative;overflow:visible;z-index:1}.about-shell{position:relative;z-index:1}@media(max-width:1300px){.about-blob-wrap{height:540px;min-height:420px}}@media(max-width:1100px){.about-card{grid-template-columns:1fr}.about-blob-wrap{order:-1;height:440px;min-height:400px;top:0}.about-content{max-width:none}}@media(max-width:640px){.about-content h3{font-size:clamp(1.7rem,3vw,4rem)}.about-text{margin:15px 0 0;font-size:clamp(1rem,1.1vw,1.18rem)}.about-heading-row h2{font-size:clamp(4.4rem,25vw,6.6rem)}.about-blob-wrap{height:320px;min-height:300px}.about-actions{gap:10px;margin-top:30px}.about-btn{width:100%;min-width:0;height:62px}}@media(max-width:440px){.about-blob-wrap{height:300px}}.project-detail-page{position:fixed;top:0;right:0;bottom:0;left:0;z-index:4200;visibility:hidden;font-family:DM Sans,sans-serif;pointer-events:auto;display:block;width:auto;min-height:0;overflow:hidden;flex:none}.project-detail-panel{display:block;width:100%;height:100vh;height:100dvh;max-height:100vh;background:#f5f5f5fa;border-right:1px solid rgba(28,28,28,.16);overflow:hidden;overscroll-behavior:contain;will-change:transform}.project-detail-bar{position:absolute;top:0;left:0;right:0;z-index:4;background:#f5f5f5fa;border-bottom:1px solid rgba(28,28,28,.12);pointer-events:none}.project-detail-bar-inner{display:flex;align-items:flex-end;min-height:196px;padding-bottom:28px}.project-detail-inner section{padding-left:0}.project-detail-scroller{height:100%;min-height:0;overflow:hidden auto;overscroll-behavior:contain;scrollbar-width:none;touch-action:pan-y}.project-detail-scroller::-webkit-scrollbar{display:none}.project-detail-inner{min-height:100%;padding-top:236px;padding-bottom:0}.project-back-link{display:inline-flex;align-items:center;gap:10px;margin:0;font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;pointer-events:auto}.project-back-link svg{width:15px;height:15px;transition:transform .25s ease}.project-back-link:hover svg{transform:translate(-3px,3px)}.project-detail-copy{position:relative;z-index:1;width:100%;min-height:calc(100vh - 236px);padding-bottom:clamp(132px,20vh,236px);min-width:0;transform-origin:50% 8%;will-change:transform,opacity,filter}.project-detail-number{display:block;margin-bottom:10px;color:#666;font-size:.9rem;letter-spacing:.08em}.project-detail-copy h1{max-width:1280px;margin:0;font-size:clamp(5.2rem,8vw,5.6rem);font-weight:400;line-height:.92;letter-spacing:-.055em}.project-detail-subtitle{max-width:760px;margin:22px 0 38px;color:#333;font-size:clamp(1.05rem,1.4vw,1.32rem);line-height:1.55}.project-meta-list{display:grid;grid-template-columns:80px 1fr 1fr;gap:18px;max-width:1180px;margin:0 0 44px}.project-meta-list div{border-top:1px solid rgba(28,28,28,.18);padding-top:12px}.project-meta-list dt,.project-detail-section h2{margin:0 0 7px;color:#666;font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase}.project-meta-list dd{margin:0;color:#333;font-size:1rem;line-height:1.55}.project-meta-stack{display:flex;flex-wrap:wrap;gap:8px}.project-meta-stack span{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border:1px solid rgba(28,28,28,.16);border-radius:3px;color:#333;font-size:1rem;line-height:1}.project-detail-section{max-width:900px;margin-top:30px}.project-detail-section--compact{margin-top:38px}.project-detail-section p{margin:0;color:#333;font-size:1rem;line-height:1.78}.project-gallery-section{position:relative;z-index:2;width:100%;margin-top:clamp(-150px,-12vh,-72px);padding:clamp(64px,10vh,112px) 0 clamp(96px,16vh,180px);overflow:hidden}.project-gallery-list{display:grid;gap:clamp(36px,8vw,120px)}.project-gallery-item{display:block;width:min(100%,760px);margin:0 auto;overflow:hidden;background:#fff;border:1px solid rgba(28,28,28,.13);border-radius:4px;box-shadow:0 30px 80px #1c1c1c21;transform-origin:50% 65%;will-change:transform,opacity}.project-gallery-item img{display:block;width:100%;height:100%;object-fit:cover;will-change:transform}@media(max-width:900px){.project-detail-bar-inner{min-height:172px;padding-bottom:24px}.project-detail-inner{padding-top:212px;min-height:100%}.project-detail-copy{min-height:calc(100vh - 212px);padding-bottom:148px}.project-gallery-section{margin-top:-48px;padding-top:58px;padding-bottom:clamp(150px,30vh,230px)}.project-gallery-list{gap:28px}.project-gallery-item{width:100%;margin-right:0;margin-left:0}}@media(max-width:600px){.project-detail-copy h1{font-size:clamp(3.5rem,8vw,4.6rem)}.project-meta-list{grid-template-columns:1fr}}
