.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}:root{--color-primary:#0C0B09;--color-secondary:#8B6A20;--color-dark:#1a1a1a;--color-light:#f5f5f5;--color-white:#ffffff;--color-cream:#f9f6f2;--font-primary:'capitolium-2',serif;--font-secondary:'iowan-old-style-bt','Georgia',serif;--transition:background 0.4s cubic-bezier(0.25,0.46,0.45,0.94),color 0.4s cubic-bezier(0.25,0.46,0.45,0.94),transform 0.4s cubic-bezier(0.25,0.46,0.45,0.94),opacity 0.4s cubic-bezier(0.25,0.46,0.45,0.94),border-color 0.4s cubic-bezier(0.25,0.46,0.45,0.94),box-shadow 0.4s cubic-bezier(0.25,0.46,0.45,0.94);--transition-fast:background 0.2s cubic-bezier(0.25,0.46,0.45,0.94),color 0.2s cubic-bezier(0.25,0.46,0.45,0.94),transform 0.2s cubic-bezier(0.25,0.46,0.45,0.94),opacity 0.2s cubic-bezier(0.25,0.46,0.45,0.94),border-color 0.2s cubic-bezier(0.25,0.46,0.45,0.94);--transition-slow:background 0.6s cubic-bezier(0.25,0.46,0.45,0.94),color 0.6s cubic-bezier(0.25,0.46,0.45,0.94),transform 0.6s cubic-bezier(0.25,0.46,0.45,0.94),opacity 0.6s cubic-bezier(0.25,0.46,0.45,0.94);--shadow:0 10px 40px rgba(0,0,0,0.1)}.loader{position:fixed;inset:0;z-index:99999;background:var(--color-primary);display:flex;align-items:center;justify-content:center;transition:opacity .6s ease,visibility .6s ease}.loader.hidden{opacity:0;visibility:hidden;pointer-events:none}.loader-inner{text-align:center}.loader-logo{width:80px;height:80px;animation:loaderSpin 2s ease-in-out infinite;filter:brightness(0) invert(1);margin-bottom:2rem}@keyframes loaderSpin{0%{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(1.1)}100%{transform:rotate(360deg) scale(1)}}.loader-bar{width:200px;height:3px;background:rgba(255,255,255,.2);border-radius:3px;overflow:hidden;margin:0 auto}.loader-progress{height:100%;width:0%;background:var(--color-secondary);border-radius:3px;transition:width .3s ease}.theme-toggle{background:0 0;border:2px solid rgba(139,106,32,.3);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;margin-left:1rem;transition:border-color .3s ease,background .3s ease;flex-shrink:0}.theme-toggle:hover{border-color:var(--color-secondary);background:rgba(139,106,32,.1)}.theme-icon{width:18px;height:18px;color:var(--color-secondary);transition:transform .3s ease}.theme-icon.moon{display:none}[data-theme=light] .theme-icon.sun{display:none}[data-theme=light] .theme-icon.moon{display:block}.wave-separator{line-height:0;margin-top:-1px;position:relative;z-index:2}.wave-separator svg{width:100%;height:60px;display:block}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;overflow-x:clip;color-scheme:light dark}body{font-family:var(--font-secondary);color:var(--color-dark);background-color:var(--color-white);line-height:1.6;touch-action:manipulation}img{max-width:100%;height:auto;display:block}a{text-decoration:none;color:inherit;transition:var(--transition);-webkit-tap-highlight-color:transparent}a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--color-secondary);outline-offset:2px}ul{list-style:none}section{scroll-margin-top:80px}.container{max-width:1200px;margin:0 auto;padding:0 1.25rem;padding-left:max(1.25rem,env(safe-area-inset-left));padding-right:max(1.25rem,env(safe-area-inset-right))}.skip-link{position:absolute;top:-100%;left:0;background:var(--color-secondary);color:var(--color-dark);padding:.75rem 1.5rem;z-index:10000;font-weight:600;border-radius:0 0 8px 0}.skip-link:focus{top:0}h1,h2,h3,h4,h5,h6{font-family:var(--font-primary);font-weight:600;line-height:1.2}.section-label{font-size:.75rem;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--color-secondary);display:block;margin-bottom:1rem}.section-title{font-size:clamp(2rem,5vw,3.5rem);color:var(--color-primary);margin-bottom:1.5rem;text-wrap:balance}.section-title-center{font-size:clamp(2rem,5vw,3.5rem);color:var(--color-primary);text-align:center;margin-bottom:2rem;text-wrap:balance}.section-title-white{font-size:clamp(2rem,5vw,3.5rem);color:var(--color-white);text-align:center;margin-bottom:1rem;text-wrap:balance}.text-gold{color:var(--color-secondary);font-style:italic}.btn{display:inline-block;padding:.875rem 2rem;font-weight:500;font-size:1rem;border-radius:50px;transition:transform .3s cubic-bezier(.25,.46,.45,.94),box-shadow .3s cubic-bezier(.25,.46,.45,.94),background .3s cubic-bezier(.25,.46,.45,.94),color .3s cubic-bezier(.25,.46,.45,.94),border-color .3s cubic-bezier(.25,.46,.45,.94);cursor:pointer;border:2px solid transparent;text-align:center;min-height:44px;min-width:44px}.btn-primary{background:var(--color-secondary);color:var(--color-dark);border-color:var(--color-secondary);font-weight:600}.btn-primary:hover{background:#b8942f;border-color:#b8942f;transform:translateY(-3px);box-shadow:0 12px 35px rgba(139,106,32,.4)}.btn-secondary{background:0 0;color:var(--color-secondary);border:2px solid var(--color-secondary);font-weight:600}.btn-secondary:hover{background:var(--color-secondary);color:var(--color-dark);transform:translateY(-3px);box-shadow:0 12px 35px rgba(139,106,32,.3)}.btn-ghost{background:0 0;color:var(--color-secondary);border:none;padding:.5rem 0;position:relative;font-weight:500}.btn-ghost::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--color-secondary);transition:width .3s cubic-bezier(.25,.46,.45,.94)}.btn-ghost:hover::after{width:100%}.btn-contact{background:0 0;color:var(--color-secondary);border:1.5px solid var(--color-secondary);padding:.75rem 2rem;border-radius:50px;font-weight:500;transition:transform .3s cubic-bezier(.25,.46,.45,.94),box-shadow .3s cubic-bezier(.25,.46,.45,.94),background .3s cubic-bezier(.25,.46,.45,.94),color .3s cubic-bezier(.25,.46,.45,.94)}.btn-contact:hover{background:var(--color-secondary);color:var(--color-dark)}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1rem 0;transition:var(--transition);background:0 0;padding-top:max(1rem,env(safe-area-inset-top))}.navbar.scrolled{background:rgba(255,255,255,.98);backdrop-filter:blur(10px);box-shadow:0 2px 20px rgba(0,0,0,.05);padding:.75rem 0;padding-top:max(.75rem,env(safe-area-inset-top))}.navbar .container{display:flex;justify-content:space-between;align-items:center}.nav-brand{display:flex;align-items:center;gap:.75rem;font-family:var(--font-primary);font-size:1.4rem;font-weight:600;color:var(--color-white);transition:var(--transition)}.nav-brand a{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:inherit}.navbar.scrolled .nav-brand{color:var(--color-primary)}.logo-icon{width:42px;height:42px;object-fit:contain}.logo-text{display:flex;flex-direction:column;line-height:1}.logo-studio{font-size:.6em;letter-spacing:2px;font-weight:400}.nav-menu{position:fixed;top:0;right:-100%;width:75%;max-width:320px;height:100vh;height:100dvh;background:var(--color-primary);flex-direction:column;justify-content:center;display:flex;gap:2rem;transition:var(--transition);box-shadow:-5px 0 20px rgba(0,0,0,.1);padding:2rem;padding-bottom:max(2rem,env(safe-area-inset-bottom));z-index:1000}.nav-menu.active{right:0}.nav-link{font-weight:500;font-size:1.25rem;color:var(--color-white);position:relative;transition:var(--transition);min-height:44px;display:flex;align-items:center}.nav-toggle{display:flex;flex-direction:column;gap:5px;background:0 0;border:none;cursor:pointer;padding:.5rem;z-index:1001;min-height:44px;min-width:44px;align-items:center;justify-content:center}.nav-toggle span{width:25px;height:2px;background:var(--color-white);transition:var(--transition)}.navbar.scrolled .nav-toggle span{background:var(--color-dark)}.video-scroll-section{display:none}@media (min-width:1024px){.video-scroll-section{display:block;position:relative;height:500vh;background:#0a0a0a}.video-scroll-canvas{position:sticky;top:0;width:100%;height:100vh;overflow:hidden}.video-scroll-frame{width:100%;height:100%;object-fit:cover;object-position:center center;will-change:transform;transform:translateZ(0)}.video-scroll-section .hero-green-reveal{position:fixed;inset:0;z-index:100;background:linear-gradient(135deg,rgba(44,95,95,.55) 0,rgba(35,73,73,.45) 100%),url('../images/hero-coast.jpg') center/cover no-repeat;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;opacity:0;transform:none;pointer-events:none;transition:opacity .6s ease}.video-scroll-section .hero-green-reveal.active{opacity:1;pointer-events:auto}.video-scroll-section .hero-green-reveal.show-content .reveal-logo{opacity:1;transform:scale(1) rotate(0)}.video-scroll-section .hero-green-reveal.show-content .reveal-title{opacity:1;transform:translateY(0) scale(1)}.video-scroll-section .hero-green-reveal.show-content .reveal-btn{opacity:1;transform:translateY(0)}}.hero-sticky-wrap{position:relative}@media (min-width:1024px){.hero-sticky-wrap{height:200vh}}.hero{position:relative;height:100vh;height:100dvh;display:flex;align-items:center;justify-content:center;background:#1a3535;overflow:hidden}@media (min-width:1024px){.hero{position:sticky;top:0}}.hero-overlay{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 30%,transparent 0,rgba(0,0,0,.4) 100%);z-index:5;pointer-events:none}.hero-green-reveal{position:absolute;inset:0;z-index:7;background:linear-gradient(135deg,var(--color-primary) 0,#1a1a1a 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;transform:translateY(100%);will-change:transform;pointer-events:none}.reveal-logo{width:100px;height:auto;opacity:0;transform:scale(.3) rotate(-10deg);transition:opacity .8s ease,transform 1s cubic-bezier(.16,1,.3,1);filter:brightness(0) invert(1)}.reveal-title{display:flex;flex-direction:column;align-items:center;text-align:center;opacity:0;transform:translateY(40px) scale(.9);transition:opacity .8s ease .2s,transform 1s cubic-bezier(.16,1,.3,1) .2s}.reveal-main{font-family:var(--font-primary);font-size:clamp(3.5rem,12vw,8rem);font-weight:400;color:var(--color-secondary);letter-spacing:.3em;line-height:1}.reveal-sub{font-family:var(--font-primary);font-size:clamp(1.2rem,4vw,2.5rem);font-weight:400;color:var(--color-white);letter-spacing:.8em;margin-top:.5rem}.reveal-subtitle{font-family:var(--font-secondary);font-style:italic;font-size:clamp(1rem,2vw,1.4rem);color:rgba(255,255,255,.85);opacity:0;transform:translateY(20px);transition:opacity .8s ease .3s,transform 1s cubic-bezier(.16,1,.3,1) .3s}.reveal-location{font-family:var(--font-primary);font-size:clamp(.7rem,1.2vw,.95rem);color:var(--color-secondary);letter-spacing:.3em;opacity:0;transform:translateY(20px);transition:opacity .8s ease .4s,transform 1s cubic-bezier(.16,1,.3,1) .4s}.hero-green-reveal.show-content .reveal-location,.hero-green-reveal.show-content .reveal-subtitle{opacity:1;transform:translateY(0)}.reveal-btn{opacity:0;transform:translateY(30px);transition:opacity .8s ease .5s,transform 1s cubic-bezier(.16,1,.3,1) .5s;pointer-events:auto}.hero-green-reveal.show-content .reveal-logo{opacity:1;transform:scale(1) rotate(0)}.hero-green-reveal.show-content .reveal-title{opacity:1;transform:translateY(0) scale(1)}.hero-green-reveal.show-content .reveal-btn{opacity:1;transform:translateY(0)}@media (min-width:1024px){.reveal-logo{width:150px}}.scroll-over-content{position:relative;z-index:2}.parallax-spacer{height:30vh;background:linear-gradient(to bottom,transparent 0,rgba(44,95,95,.3) 40%,var(--color-primary) 100%);pointer-events:none}.hero-video-bg{position:absolute;inset:0;z-index:2}.hero-video-bg img{will-change:transform;transform:translateZ(0)}.hero-video{width:100%;height:100%;object-fit:cover;object-position:center center}body.video-locked{overflow:hidden}.hero-background{position:absolute;inset:0;z-index:1;overflow:hidden}.hero-bg-img{width:100%;height:100%;object-fit:cover;object-position:center center}.hero-content-wrapper{position:relative;z-index:10;display:flex;align-items:center;justify-content:center;width:100%;height:100%;pointer-events:none}.hero-content-wrapper .hero-content{pointer-events:auto}.hero-content{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;position:absolute;top:0;left:0;right:0;bottom:0;z-index:5;padding:2rem;background:linear-gradient(135deg,rgba(44,95,95,.85) 0,rgba(26,26,26,.8) 100%)}.hero-content.visible{opacity:1;transform:none;animation:contentReveal 1.2s ease-out forwards}.hero-logo{width:80px;height:80px;margin:0 auto 1.5rem;object-fit:contain;filter:drop-shadow(0 10px 30px rgba(139,106,32,.3))}.tree-animation{animation:float 6s ease-in-out infinite}@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}.hero-title{margin-bottom:1.25rem}.title-main{display:block;font-size:clamp(2.5rem,10vw,6rem);font-weight:700;color:var(--color-white);letter-spacing:.1em;line-height:1}.title-sub{display:block;font-size:clamp(1.2rem,5vw,2.5rem);font-weight:300;color:var(--color-secondary);letter-spacing:.3em;margin-top:.5rem}.hero-subtitle{font-size:clamp(.95rem,2.5vw,1.25rem);color:rgba(255,255,255,.9);max-width:700px;margin:0 auto 2rem;line-height:1.8;font-weight:300}.scroll-indicator{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:10;opacity:1;padding-bottom:env(safe-area-inset-bottom)}.scroll-indicator.visible{opacity:1}.scroll-line{width:2px;height:40px;background:linear-gradient(to bottom,var(--color-secondary),transparent)}.scroll-indicator.visible .scroll-line{animation:scroll 2s ease-in-out infinite}@keyframes scroll{0%,100%{transform:translateY(0);opacity:0}50%{opacity:1}100%{transform:translateY(20px);opacity:0}}.stats-marquee{padding:1.5rem 0;background:var(--color-primary);overflow:hidden}.stats-marquee-track{display:flex;width:max-content;animation:statsScroll 25s linear infinite}.stats-marquee-content{display:flex;align-items:center;flex-shrink:0}.stat-marquee-word{font-family:var(--font-primary);font-size:clamp(2rem,4vw,3.5rem);font-weight:700;color:var(--color-secondary);white-space:nowrap;padding:0 2.5rem;letter-spacing:.08em;text-transform:uppercase}.stat-marquee-word.outline{color:transparent;-webkit-text-stroke:1.5px rgba(255,255,255,0.4)}@keyframes statsScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}.stats-marquee:hover .stats-marquee-track{animation-play-state:paused}.stats{padding:3rem 0;background:linear-gradient(135deg,var(--color-primary) 0,#1a1a1a 100%)}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;text-align:center}.stat-item{position:relative;padding:1rem}.stat-number{font-size:clamp(2.5rem,6vw,4.5rem);font-weight:700;font-family:var(--font-primary);color:var(--color-secondary);line-height:1;margin-bottom:.5rem;display:inline-block;font-variant-numeric:tabular-nums}.stat-suffix{font-size:clamp(1.5rem,4vw,3rem);color:var(--color-secondary);display:inline-block;margin-left:.25rem}.stat-label{color:rgba(255,255,255,.9);font-size:.95rem;font-weight:500}.about{padding:4rem 0;background:var(--color-cream)}.about-grid{display:grid;grid-template-columns:1fr;gap:2.5rem}.about-text{font-size:1.05rem;line-height:1.8;margin-bottom:1.5rem;color:#444}.about-features{display:flex;flex-wrap:wrap;gap:.75rem}.feature-tag{padding:.625rem 1.25rem;background:var(--color-primary);color:var(--color-white);border-radius:50px;font-size:.85rem;font-weight:500}.about-image{position:relative;width:100%;display:grid;gap:1rem}.about-image picture{position:relative;width:100%;border-radius:15px;overflow:hidden;box-shadow:var(--shadow)}.about-image picture:first-child{height:0;padding-bottom:100%}.about-image picture:first-child img{position:absolute;top:0;left:0}.about-image img{width:100%;height:100%;object-fit:cover}.about-image-secondary{height:0;padding-bottom:50%}.about-image-secondary img{position:absolute;top:0;left:0}.about-text-secondary{margin-top:.5rem;opacity:.85;font-size:.95rem}.services{padding:0;background:var(--color-dark);position:relative}.section-header-full{position:relative;background:var(--color-primary);padding:2.5rem 1.25rem;text-align:center;z-index:10}.section-header-full .section-title-center{color:var(--color-white);margin-bottom:0}.section-header{margin-bottom:3rem}.why-us{padding:4rem 1.25rem;background:var(--color-light)}.why-us-header{text-align:center;margin-bottom:2.5rem}.why-us-header .section-label{color:var(--color-secondary);font-size:.85rem;letter-spacing:3px;margin-bottom:1rem;display:block}.why-us-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;max-width:1200px;margin:0 auto}.why-us-card{background:var(--color-white);border-radius:1rem;padding:2rem 1.5rem;border:1px solid rgba(139,106,32,.1);transition:transform .4s ease,box-shadow .4s ease,background .4s ease,border-color .4s ease}.why-us-card:hover{background:var(--color-secondary);border-color:var(--color-secondary)}.why-us-card:hover .why-us-icon{background:rgba(255,255,255,.25);color:#fff}.why-us-card:hover .why-us-title{color:#fff}.why-us-card:hover .why-us-desc{color:rgba(255,255,255,.85)}.why-us-icon{width:56px;height:56px;border-radius:50%;background:rgba(139,106,32,.1);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;color:var(--color-secondary);transition:background .4s ease,color .4s ease}.why-us-title{font-family:var(--font-secondary);font-size:1.15rem;color:var(--color-primary);margin-bottom:.75rem;font-weight:500;transition:color .4s ease}.why-us-desc{font-size:.9rem;color:rgba(0,0,0,.6);line-height:1.6;transition:color .4s ease}.tag{padding:.5rem 1rem;background:var(--color-cream);color:var(--color-primary);border-radius:50px;font-size:.85rem;font-weight:500}.services-showcase{padding:4rem 0 0;background:var(--color-dark)}.services-showcase-header{text-align:center;padding:0 1.25rem 2rem}.services-showcase-header .section-label{color:var(--color-secondary);font-size:.85rem;letter-spacing:3px;margin-bottom:1rem;display:block}.services-showcase-header .section-title-center{color:var(--color-white)}.rolling-stack{display:flex;flex-direction:column;gap:1.5rem;padding:1rem}.rolling-card{display:block;border-radius:1rem;overflow:hidden;background:#0C0B09;position:relative;text-decoration:none;color:inherit;cursor:pointer}.rolling-subtitle{font-style:italic;color:var(--color-secondary);font-weight:300;font-size:.75em}.rolling-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.rolling-tag{padding:.35rem .75rem;border:1px solid rgba(139,106,32,.3);border-radius:2rem;font-size:.75rem;color:var(--color-secondary);letter-spacing:.5px;font-family:var(--font-secondary);transition:background .3s ease,color .3s ease}.rolling-card:hover .rolling-tag{background:rgba(139,106,32,.15)}.rolling-cta{display:inline-block;margin-top:1rem;font-size:.85rem;color:var(--color-secondary);letter-spacing:1px;font-family:var(--font-secondary);transition:transform .3s ease}.rolling-card:hover .rolling-cta{transform:translateX(8px)}.rolling-card-img-wrap{overflow:hidden;border-radius:1rem 1rem 0 0}.rolling-img{width:100%;aspect-ratio:16/10;background-size:cover;background-position:center}.rolling-video{width:100%;aspect-ratio:16/10;object-fit:cover;display:block}.rolling-info{padding:1.25rem;position:relative}.rolling-number{font-family:var(--font-secondary);font-size:.75rem;color:var(--color-secondary);letter-spacing:2px;display:block;margin-bottom:.35rem}.rolling-info h3{font-family:var(--font-secondary);font-size:1.2rem;color:var(--color-white);margin-bottom:.35rem;font-weight:400}.rolling-info p{font-size:.85rem;color:rgba(255,255,255,.8);line-height:1.4}.rolling-counter{display:none}.portfolio{padding:0;background:var(--color-light);position:relative;--gap:clamp(10px,7.35vw,80px);--gutter:1rem;--power-1-out:linear(0 0%,0.0027 3.64%,0.0106 7.29%,0.0425 14.58%,0.0957 21.87%,0.1701 29.16%,0.2477 35.19%,0.3401 41.23%,0.5982 55.18%,0.7044 61.56%,0.7987 68.28%,0.875 75%,0.9297 81.25%,0.9687 87.5%,0.9922 93.75%,1 100%);--power-2-out:linear(0 0%,0.0036 9.62%,0.0185 16.66%,0.0489 23.03%,0.0962 28.86%,0.1705 34.93%,0.269 40.66%,0.3867 45.89%,0.5833 52.95%,0.683 57.05%,0.7829 62.14%,0.8621 67.46%,0.8991 70.68%,0.9299 74.03%,0.9545 77.52%,0.9735 81.21%,0.9865 85%,0.9949 89.15%,1 100%);--power-4-out:linear(0 0%,0.0012 14.95%,0.0089 22.36%,0.0297 28.43%,0.0668 33.43%,0.0979 36.08%,0.1363 38.55%,0.2373 43.07%,0.3675 47.01%,0.5984 52.15%,0.7121 55.23%,0.8192 59.21%,0.898 63.62%,0.9297 66.23%,0.9546 69.06%,0.9733 72.17%,0.9864 75.67%,0.9982 83.73%,1 100%);--sine:linear(0 0%,0.2861 18.47%,0.4829 32.08%,0.6437 44.52%,0.7712 56.07%,0.8722 67.47%,0.9115 73.02%,0.9434 78.49%,0.9682 83.91%,0.9859 89.3%,0.9965 94.66%,1 100%)}@keyframes portfolio-fade{0%,55%{opacity:0}}@keyframes portfolio-reveal{0%,30%{scale:0}}@keyframes portfolio-scale-x{0%,10%{width:calc(100vw - (2 * var(--gutter)))}}@keyframes portfolio-scale-y{0%,10%{height:calc(100vh - (2 * var(--gutter)))}}@keyframes scrollPulse{0%,100%{opacity:1;transform:scaleY(1)}50%{opacity:.5;transform:scaleY(.8)}}.portfolio-intro{min-height:50vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:3rem 1.25rem}.portfolio-intro .section-label{color:var(--color-secondary);font-size:.85rem;letter-spacing:3px;margin-bottom:1rem;display:block}.portfolio-intro-title{font-family:var(--font-secondary);font-size:clamp(2rem,6vw,5rem);color:var(--color-primary);margin-bottom:1rem;font-weight:400}.portfolio-intro-subtitle{font-size:1rem;color:var(--color-dark);max-width:500px;margin-bottom:2rem}.scroll-indicator-portfolio{display:flex;flex-direction:column;align-items:center;gap:.75rem;color:var(--color-primary);font-size:.75rem;letter-spacing:2px;text-transform:uppercase;opacity:.6}.scroll-indicator-portfolio .scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--color-primary),transparent);animation:scrollPulse 2s ease-in-out infinite}.portfolio-item{position:relative;border-radius:.75rem;overflow:hidden;cursor:pointer}.portfolio-img{width:100%;aspect-ratio:4/5;border-radius:.75rem;background-size:cover;background-position:center}.portfolio-img[data-project="1"]{background-image:url('../images/portfolio/project-01.webp')}.portfolio-img[data-project="2"]{background-image:url('../images/portfolio/project-02.webp')}.portfolio-img[data-project="3"]{background-image:url('../images/portfolio/project-03.webp')}.portfolio-img[data-project="4"]{background-image:url('../images/portfolio/project-04.webp')}.portfolio-img[data-project="5"]{background-image:url('../images/portfolio/project-05.webp')}.portfolio-img[data-project="6"]{background-image:url('../images/portfolio/project-06.webp')}.portfolio-img[data-project="7"]{background-image:url('../images/portfolio/project-07.webp')}.portfolio-img[data-project="8"]{background-image:url('../images/portfolio/project-08.webp')}.portfolio-img[data-project="9"]{background-image:url('../images/portfolio/project-09.webp')}.portfolio-img[data-project="10"]{background-image:url('../images/portfolio/project-10.webp')}.portfolio-img[data-project="11"]{background-image:url('../images/portfolio/project-11.webp')}.portfolio-img[data-project="12"]{background-image:url('../images/portfolio/project-12.webp')}.portfolio-img[data-project="13"]{background-image:url('../images/portfolio/project-13.webp')}.portfolio-img[data-project="14"]{background-image:url('../images/portfolio/project-14.webp')}.portfolio-img-main{background-image:url('../images/portfolio/project-main.webp');background-size:cover;background-position:center;border-radius:1rem}.portfolio-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.85) 0,transparent 60%);display:flex;flex-direction:column;justify-content:flex-end;padding:.75rem;opacity:1}.portfolio-category{font-size:.6rem;font-weight:600;letter-spacing:2px;color:var(--color-secondary);margin-bottom:.25rem}.portfolio-title{font-size:.8rem;color:var(--color-white);font-family:var(--font-secondary)}.portfolio-end{min-height:30vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;background:var(--color-light);padding:2rem 1rem}.portfolio-section{min-height:auto}.portfolio-content{height:auto;position:relative;padding:1rem}.portfolio-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--gap);max-width:calc(100% - (2 * var(--gutter)));margin:0 auto}.portfolio-grid>.layer{display:contents}.portfolio-grid .scaler{grid-column:1/-1;grid-row:1;margin-bottom:.5rem}.scaler .portfolio-img-main{width:100%;aspect-ratio:4/5;box-shadow:0 10px 30px rgba(0,0,0,.15)}.testimonials{padding:4rem 0;background:var(--color-white)}.testimonials-carousel{position:relative;overflow:hidden}.testimonials-track{display:flex;transition:transform .5s cubic-bezier(.25,.46,.45,.94)}.testimonials-track .testimonial-card{min-width:100%;box-sizing:border-box}.testimonials-nav{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:2rem}.testimonial-next,.testimonial-prev{background:var(--color-primary);color:var(--color-white);border:none;width:40px;height:40px;border-radius:50%;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.testimonial-next:hover,.testimonial-prev:hover{background:var(--color-secondary);transform:scale(1.1)}.testimonial-dots{display:flex;gap:.5rem}.testimonial-dot{width:10px;height:10px;border-radius:50%;background:#ccc;border:none;cursor:pointer;transition:var(--transition);padding:0}.testimonial-dot.active{background:var(--color-secondary);transform:scale(1.3)}.testimonial-card{padding:2rem;border-radius:15px;background:var(--color-cream);transition:var(--transition);position:relative}.testimonial-stars{color:var(--color-secondary);font-size:1.125rem;margin-bottom:1rem;letter-spacing:2px}.testimonial-text{color:#444;line-height:1.8;margin-bottom:1.5rem;font-size:.95rem;font-style:italic}.testimonial-author{display:flex;align-items:center;gap:1rem}.author-avatar{width:45px;height:45px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:var(--color-white);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0}.author-info{flex:1}.author-name{font-weight:600;color:var(--color-dark);margin-bottom:.25rem}.author-company{font-size:.85rem;color:#666}.methode{padding:4rem 0;background:var(--color-primary);position:relative}.methode::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg width="100" height="100" xmlns="http://www.w3.org/2000/svg"><defs><pattern id="dots" width="20" height="20" patternUnits="userSpaceOnUse"><circle cx="2" cy="2" r="1" fill="rgba(255,255,255,0.05)"/></pattern></defs><rect width="100%" height="100%" fill="url(%23dots)"/></svg>')}.methode-header{text-align:center;margin-bottom:3rem;position:relative;z-index:1}.methode-subtitle{color:rgba(255,255,255,.8);font-size:1rem;margin-top:1rem}.methode-steps{max-width:900px;margin:0 auto 3rem;position:relative;z-index:1}.step{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:2.5rem;position:relative}.step-number{width:60px;height:60px;background:var(--color-secondary);color:var(--color-dark);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;font-family:var(--font-primary);flex-shrink:0;box-shadow:0 10px 30px rgba(139,106,32,.3)}.step:not(:last-child)::after{display:none}.step-content{padding-top:0}.step-title{font-size:1.5rem;color:var(--color-secondary);margin-bottom:.75rem}.step-description{color:rgba(255,255,255,.9);line-height:1.8;font-size:1rem}.cta-box{background:rgba(255,255,255,.05);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.1);border-radius:20px;padding:2rem;text-align:center;max-width:700px;margin:0 auto;position:relative;z-index:1}.cta-title{font-size:1.5rem;color:var(--color-white);margin-bottom:.75rem}.cta-text{color:rgba(255,255,255,.8);margin-bottom:1.5rem;font-size:1rem}.faq{padding:4rem 0;background:var(--color-light)}.faq-header{text-align:center;margin-bottom:2.5rem}.faq-grid{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:1rem}.faq-item{background:var(--color-white);border-radius:12px;overflow:hidden;box-shadow:0 2px 10px rgba(0,0,0,.05);transition:var(--transition)}.faq-question{width:100%;padding:1.25rem 1.25rem;background:0 0;border:none;text-align:left;font-size:1rem;font-weight:600;color:var(--color-dark);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;transition:var(--transition);font-family:var(--font-secondary);min-height:44px}.faq-icon{font-size:1.5rem;color:var(--color-secondary);transition:var(--transition);flex-shrink:0}.faq-item.active .faq-icon{transform:rotate(45deg)}.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1)}.faq-item.active .faq-answer{max-height:500px}.faq-answer p{padding:0 1.25rem 1.25rem;color:#555;line-height:1.8}.contact{position:relative;padding:4rem 0;padding-bottom:max(4rem,env(safe-area-inset-bottom));background:linear-gradient(135deg,#0C0B09 0,var(--color-dark) 100%);overflow:hidden}.contact-overlay{position:absolute;inset:0;background:url('data:image/svg+xml,<svg width="100" height="100" xmlns="http://www.w3.org/2000/svg"><defs><pattern id="grid2" width="50" height="50" patternUnits="userSpaceOnUse"><path d="M 50 0 L 0 0 0 50" fill="none" stroke="rgba(139,106,32,0.05)" stroke-width="1"/></pattern></defs><rect width="100%" height="100%" fill="url(%23grid2)"/></svg>')}.contact-wrapper{display:grid;grid-template-columns:1fr;gap:2.5rem;align-items:start}.contact-info-section{position:relative;z-index:1;text-align:center}.contact-content{position:relative;z-index:1;text-align:center;max-width:800px;margin:0 auto}.contact-logo{width:60px;height:60px;margin:0 auto 1.5rem;object-fit:contain;filter:drop-shadow(0 5px 20px rgba(139,106,32,.3))}.contact-title{font-size:clamp(2rem,5vw,4rem);color:var(--color-white);margin-bottom:1rem}.contact-subtitle{font-size:1rem;color:rgba(255,255,255,.85);margin-bottom:2.5rem;line-height:1.8}.contact-methods{display:grid;grid-template-columns:1fr;gap:2rem;margin-bottom:2rem}.contact-method{text-align:center}.contact-icon{width:40px;height:40px;margin:0 auto .75rem;color:var(--color-secondary)}.contact-icon svg{width:100%;height:100%}.contact-label{display:block;font-size:.75rem;font-weight:600;letter-spacing:2px;color:var(--color-secondary);margin-bottom:.5rem}.contact-link{display:block;color:var(--color-white);font-size:1rem;margin-bottom:.5rem;transition:var(--transition);min-height:44px;display:flex;align-items:center;justify-content:center}.contact-text{color:var(--color-white);font-size:1rem}.social-links{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:2rem}.social-link{width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.1);border-radius:50%;color:var(--color-secondary);transition:var(--transition)}.social-link svg{width:24px;height:24px}.instagram-handle{color:rgba(255,255,255,.85);font-size:1rem}.contact-form-section{position:relative;z-index:1;padding:2rem 1.25rem;border-radius:15px;background:rgba(255,255,255,.05)}.form-title{font-size:1.5rem;color:var(--color-white);margin-bottom:.5rem;font-family:var(--font-primary)}.form-subtitle{color:var(--color-secondary);margin-bottom:1.5rem;font-size:.9rem}.contact-form{display:flex;flex-direction:column;gap:1.25rem}.form-row{display:grid;grid-template-columns:1fr;gap:1.25rem}.form-group{display:flex;flex-direction:column}.form-group label{color:rgba(255,255,255,.9);font-size:.9rem;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{padding:.875rem 1rem;border:1px solid rgba(255,255,255,.1);border-radius:10px;background:rgba(255,255,255,.05);color:var(--color-white);font-size:16px;font-family:var(--font-secondary);transition:var(--transition);min-height:44px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:2px solid var(--color-secondary);outline-offset:2px;border-color:var(--color-secondary);background:rgba(255,255,255,.08)}.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(255,255,255,.75)}.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='rgba(255,255,255,0.6)' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}.form-group select option{background:var(--color-dark);color:var(--color-white)}.form-group textarea{resize:vertical;min-height:120px}.checkbox-group{flex-direction:row}.checkbox-label{display:flex;align-items:start;gap:.75rem;color:rgba(255,255,255,.8);font-size:.85rem;cursor:pointer}.checkbox-label input[type=checkbox]{margin-top:.25rem;cursor:pointer;min-width:20px;min-height:20px}.btn-submit{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;font-size:1rem;padding:1rem 2rem;min-height:50px}.btn-icon{width:20px;height:20px;transition:var(--transition)}.form-notice{text-align:center;font-size:.8rem;color:rgba(255,255,255,.8);margin-top:.5rem}.form-success{text-align:center;padding:2rem}.success-icon{width:70px;height:70px;border-radius:50%;background:var(--color-secondary);color:var(--color-dark);font-size:2.5rem;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;animation:scaleIn .5s ease-out}@keyframes scaleIn{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.form-success h3{color:var(--color-white);font-size:1.75rem;margin-bottom:1rem}.form-success p{color:rgba(255,255,255,.8);font-size:1rem}.footer{background:var(--color-dark);padding:2rem 0;padding-bottom:max(2rem,env(safe-area-inset-bottom))}.footer-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;padding-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:1.5rem}.footer-brand .logo-text{font-size:1.5rem;display:block;margin-bottom:.75rem;color:var(--color-white);font-family:var(--font-primary);font-weight:600}.footer-tagline{color:rgba(255,255,255,.8);font-size:.9rem;margin-bottom:1.25rem;font-style:italic}.footer-social a{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.1);color:var(--color-secondary);transition:var(--transition)}.footer-heading{font-family:var(--font-secondary);font-size:.85rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--color-secondary);margin-bottom:1rem}.footer-links ul{list-style:none;padding:0}.footer-links ul li{margin-bottom:.5rem}.footer-links ul li,.footer-links ul li a{color:rgba(255,255,255,.8);font-size:.9rem;transition:var(--transition)}.footer-content{text-align:center}.footer-text{color:rgba(255,255,255,.8);font-size:.85rem;margin-bottom:.5rem}.footer-bottom{text-align:center}.footer-bottom .footer-text{font-size:.8rem;color:rgba(255,255,255,.75)}.glass-effect{background:rgba(255,255,255,.08);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.18)}@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.fade-in-up{animation:fadeInUp .8s ease-out forwards}@keyframes fadeIn{to{opacity:1}}@keyframes contentReveal{to{opacity:1;transform:translateY(0)}}.legal-page{padding:100px 0 60px;min-height:100vh}.legal-page h1{font-size:2rem;color:var(--color-primary);margin-bottom:1.5rem}.legal-page h2{font-size:1.25rem;color:var(--color-primary);margin-top:2rem;margin-bottom:.75rem}.legal-page p{color:#444;line-height:1.8;margin-bottom:1rem}@media (min-width:768px){.container{padding:0 2rem}.nav-brand{font-size:1.5rem}.logo-icon{width:40px;height:40px}.hero-content{padding:2rem}.hero-logo{width:100px;height:100px;margin-bottom:2rem}.scroll-indicator{bottom:3rem}.scroll-line{height:60px}.stats{padding:4rem 0}.stats-grid{grid-template-columns:repeat(4,1fr);gap:2rem}.stat-item{padding:1.5rem}.about{padding:6rem 0}.about-grid{grid-template-columns:1fr 1fr;gap:4rem;align-items:center}.about-text{font-size:1.125rem}.about-image picture:first-child{padding-bottom:120%;border-radius:20px}.about-image-secondary{padding-bottom:45%;border-radius:20px}.why-us-grid{grid-template-columns:repeat(2,1fr);gap:2rem}.portfolio{--gap:clamp(10px,3vw,30px);--gutter:2rem}.portfolio-intro{min-height:60vh}.portfolio-grid{grid-template-columns:repeat(3,1fr)}.portfolio-overlay{padding:1rem}.portfolio-category{font-size:.65rem}.portfolio-title{font-size:.85rem}.testimonials{padding:6rem 0}.testimonials-track .testimonial-card{min-width:50%;padding:2.5rem}.methode{padding:6rem 0}.methode-header{margin-bottom:4rem}.step{grid-template-columns:auto 1fr;gap:2rem}.step-number{width:70px;height:70px;font-size:1.75rem}.step:not(:last-child)::after{display:block;content:'';position:absolute;left:35px;top:70px;width:2px;height:calc(100% + 2.5rem);background:linear-gradient(to bottom,var(--color-secondary),transparent);opacity:.3}.step-content{padding-top:.5rem}.cta-box{padding:3rem;border-radius:30px}.cta-title{font-size:1.75rem}.faq{padding:6rem 0}.faq-header{margin-bottom:3rem}.faq-question{padding:1.5rem 2rem;font-size:1.125rem}.faq-answer p{padding:0 2rem 2rem}.contact{padding:6rem 0}.contact-wrapper{grid-template-columns:1fr 1fr;gap:4rem}.contact-info-section{text-align:left}.contact-logo{width:70px;height:70px;margin:0 0 1.5rem}.contact-methods{grid-template-columns:1fr}.contact-method{text-align:left}.contact-icon{margin:0 0 .75rem}.contact-link{justify-content:flex-start}.social-links{justify-content:flex-start}.contact-form-section{padding:2.5rem}.form-row{grid-template-columns:1fr 1fr;gap:1.5rem}.form-title{font-size:1.75rem}.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}.legal-page{padding:120px 0 80px}.legal-page h1{font-size:2.5rem}.legal-page h2{font-size:1.5rem}}@media (min-width:1024px){.section-title{margin-bottom:2rem}.section-title-center{margin-bottom:3rem}.nav-menu{position:static;width:auto;height:auto;background:0 0;flex-direction:row;box-shadow:none;padding:0;gap:2rem}.nav-link{font-size:1.05rem;color:var(--color-white);min-height:auto}.navbar.scrolled .nav-link{color:var(--color-dark)}.nav-link:not(.btn-contact)::after{content:'';position:absolute;bottom:-5px;left:0;width:0;height:2px;background:var(--color-secondary);transition:var(--transition)}.nav-link:not(.btn-contact):hover::after{width:100%}.nav-link:not(.btn-contact):hover{color:var(--color-secondary)}.nav-toggle{display:none}.navbar{padding:1.5rem 0}.navbar.scrolled{padding:1rem 0}.hero-content{opacity:1;transform:none}.hero-logo{width:120px;height:120px}.about{padding:8rem 0}.about-grid{gap:5rem}.section-header-full{position:absolute;top:0;left:0;right:0;padding:2rem;background:linear-gradient(to bottom,rgba(0,0,0,.5) 0,transparent 100%)}.why-us{padding:6rem 2rem}.why-us-grid{grid-template-columns:repeat(4,1fr);gap:2rem}.why-us-card{padding:2.5rem 2rem}.why-us-card:hover{transform:translateY(-8px);box-shadow:0 20px 50px rgba(0,0,0,.08)}.why-us-title{font-size:1.25rem}.why-us-desc{font-size:.95rem}.portfolio{--gap:clamp(10px,4vw,40px);--gutter:2rem}.portfolio-intro{min-height:100vh;padding:2rem}.portfolio-intro-title{font-size:clamp(2.5rem,8vw,5rem)}.portfolio-intro-subtitle{font-size:1.2rem;margin-bottom:3rem}.scroll-indicator-portfolio .scroll-line{height:50px}.services-showcase{padding:0}.services-showcase .services-showcase-header{position:sticky;top:0;z-index:0;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--color-primary);padding:2rem}.services-showcase-header .section-title-center{font-size:6rem;letter-spacing:3px}.rolling-stack{position:relative;display:block;padding:0;gap:0}.rolling-card{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;border-radius:0;margin:0;background:#000;overflow:hidden}.rolling-card-img-wrap{position:absolute;top:0;left:0;right:0;bottom:0}.rolling-img{width:100%;height:100%;background-size:cover;background-position:center}.rolling-video{width:100%;height:100%;object-fit:cover}.rolling-card::after{content:none}.rolling-info{position:relative;z-index:2;padding:3rem 4rem 4rem;background:linear-gradient(to top,rgba(0,0,0,.85) 0,rgba(0,0,0,.4) 80%,transparent 100%);width:100%}.rolling-number{font-size:1.2rem;margin-bottom:.75rem}.rolling-info h3{font-size:2.5rem;margin-bottom:.75rem}.rolling-info p{font-size:1.15rem;color:rgba(255,255,255,.9);max-width:600px}.rolling-tags{margin-top:1.25rem}.rolling-tag{font-size:.85rem;padding:.4rem 1rem}.rolling-cta{font-size:1rem;margin-top:1.5rem}.portfolio{--gutter:2rem}.portfolio-section{min-height:240vh}.portfolio-content{min-height:100vh;width:100vw;display:flex;place-items:center;align-content:center;position:sticky;top:0;overflow:hidden;height:auto;padding:0}.portfolio-grid{width:1400px;max-width:calc(100% - (2 * var(--gutter)));grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(3,auto);gap:var(--gap);position:absolute;top:50%;left:50%;translate:-50% -50%}.portfolio-grid>.layer{display:grid;grid-column:1/-1;grid-row:1/-1;grid-template-columns:subgrid;grid-template-rows:subgrid}.portfolio-grid>.layer:first-of-type .portfolio-item:nth-child(odd){grid-column:1}.portfolio-grid>.layer:first-of-type .portfolio-item:nth-child(2n){grid-column:-2}.portfolio-grid>.layer:nth-of-type(2) .portfolio-item:nth-child(odd){grid-column:2}.portfolio-grid>.layer:nth-of-type(2) .portfolio-item:nth-child(2n){grid-column:-3}.portfolio-grid>.layer:nth-of-type(3) .portfolio-item{grid-column:3}.portfolio-grid>.layer:nth-of-type(3) .portfolio-item:last-of-type{grid-row:-1}.portfolio-grid .scaler{grid-area:2/3;z-index:2;position:relative;width:100%;height:100%}.scaler .portfolio-img-main{position:absolute;top:50%;left:50%;translate:-50% -50%;width:100%;height:100%;aspect-ratio:auto;border-radius:1rem;box-shadow:0 30px 60px rgba(0,0,0,.25)}@supports (animation-timeline:scroll()) and (animation-range:0 100%){.portfolio-section{view-timeline:--portfolio}.scaler .portfolio-img-main{animation-name:portfolio-scale-x,portfolio-scale-y;animation-fill-mode:both;animation-timing-function:var(--power-2-out),var(--power-1-out);animation-timeline:--portfolio,--portfolio;animation-range:entry 100% exit -20%}.portfolio-grid>.layer{animation-name:portfolio-fade,portfolio-reveal;animation-fill-mode:both;animation-timeline:--portfolio,--portfolio;animation-timing-function:var(--sine),var(--power-1-out);animation-range:entry 100% exit 0%}.portfolio-grid>.layer:first-of-type{animation-timing-function:var(--sine),var(--power-1-out);animation-range:entry 100% exit 0%}.portfolio-grid>.layer:nth-of-type(2){animation-timing-function:var(--sine),var(--power-4-out);animation-range:entry 100% exit -10%}.portfolio-grid>.layer:nth-of-type(3){animation-timing-function:var(--sine),var(--power-4-out);animation-range:entry 100% exit -20%}}.portfolio-img{transition:transform .6s cubic-bezier(.25,.46,.45,.94)}.portfolio-item:hover .portfolio-img{transform:scale(1.05)}.portfolio-overlay{opacity:0;padding:1rem;transition:opacity .4s ease}.portfolio-item:hover .portfolio-overlay{opacity:1}.portfolio-category{font-size:.65rem}.portfolio-title{font-size:.9rem}.portfolio-end{min-height:50vh}.testimonials{padding:8rem 0}.testimonials-track .testimonial-card{min-width:33.333%}.testimonial-card:hover{transform:translateY(-10px);box-shadow:0 20px 50px rgba(0,0,0,.1)}.testimonial-stars{font-size:1.25rem;margin-bottom:1.5rem}.testimonial-text{margin-bottom:2rem;font-size:1.05rem}.author-avatar{width:50px;height:50px;font-size:1.125rem}.methode{padding:8rem 0}.methode-header{margin-bottom:5rem}.methode-subtitle{font-size:1.125rem}.methode-steps{margin-bottom:5rem}.step{margin-bottom:3rem}.step-number{width:80px;height:80px;font-size:2rem}.step:not(:last-child)::after{left:38px;top:76px;height:calc(100% + 3rem)}.step-title{font-size:1.75rem}.step-description{font-size:1.05rem}.cta-title{font-size:2rem}.cta-text{font-size:1.05rem;margin-bottom:2rem}.faq{padding:8rem 0}.faq-header{margin-bottom:4rem}.faq-item:hover{box-shadow:0 5px 20px rgba(0,0,0,.1)}.faq-question:hover{color:var(--color-primary)}.contact{padding:8rem 0}.contact-wrapper{gap:5rem}.contact-logo{width:80px;height:80px;margin:0 0 2rem}.contact-subtitle{font-size:1.125rem;margin-bottom:4rem}.contact-link{font-size:1.125rem}.contact-text{font-size:1.125rem}.contact-icon{width:50px;height:50px}.contact-form-section{padding:3rem;border-radius:20px}.form-title{font-size:2rem}.form-subtitle{margin-bottom:2rem}.btn-submit{font-size:1.125rem;padding:1.25rem 2.5rem}.btn-submit:hover .btn-icon{transform:translateX(5px)}.contact-link:hover{color:var(--color-secondary)}.social-link:hover{background:var(--color-secondary);color:var(--color-dark);transform:translateY(-5px)}.footer-social a:hover{background:var(--color-secondary);color:var(--color-dark)}.footer-links ul li a:hover{color:var(--color-secondary)}.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem}}@media (min-width:1400px){.container{max-width:1400px}.portfolio-grid{width:1600px}.stat-label{font-size:1.125rem}}.svc-stack{position:relative}.svc-slide{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;justify-content:flex-end;background-size:cover;background-position:center;background-color:#000;text-decoration:none;color:inherit;overflow:hidden}.svc-slide-video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.svc-header{position:sticky;top:0;height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-primary);z-index:0}.svc-header h2{font-family:var(--font-primary);font-size:clamp(2.5rem,8vw,6rem);color:var(--color-white);letter-spacing:3px;text-align:center}.svc-info{position:relative;z-index:2;padding:3rem 4rem 4rem;background:linear-gradient(to top,rgba(0,0,0,.85) 0,rgba(0,0,0,.4) 70%,transparent 100%)}.svc-number{font-family:var(--font-primary);font-size:1.1rem;color:var(--color-secondary);letter-spacing:2px;display:block;margin-bottom:.5rem}.svc-info h3{font-family:var(--font-primary);font-size:clamp(1.5rem,3vw,2.5rem);color:#fff;font-weight:400;margin-bottom:.5rem}.svc-info h3 em{font-style:italic;color:var(--color-secondary);font-weight:300;font-size:.75em}.svc-info p{font-size:clamp(.85rem,1.2vw,1.15rem);color:rgba(255,255,255,.9);max-width:600px;line-height:1.6}.svc-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.svc-tag{padding:.4rem 1rem;border:1px solid rgba(139,106,32,.3);border-radius:2rem;font-size:clamp(.7rem,.9vw,.85rem);color:var(--color-secondary);letter-spacing:.5px}.svc-cta{display:inline-block;margin-top:1rem;font-size:1rem;color:var(--color-secondary);letter-spacing:1px}@media (max-width:1023px){.svc-header{height:auto;min-height:30vh;padding:100px 1.25rem 2rem;position:relative}.svc-slide{position:relative;height:auto;min-height:60vh;border-radius:1rem;margin:0 1rem 1.5rem}.svc-info{padding:1.5rem}}.hero-combined{position:relative;height:500vh;background:#0C0B09}.hero-combined-sticky{position:sticky;top:0;height:100vh;width:100%;overflow:hidden;cursor:default}#leavesCanvas{position:absolute;top:0;left:0;width:100%;height:100%;z-index:6;pointer-events:none}.magnetic-glow{position:fixed;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(139,106,32,.04) 0,transparent 70%);pointer-events:none;z-index:8;transform:translate(-50%,-50%)}.magnetic-layer{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:7;pointer-events:none}.magnetic-layer>*{pointer-events:auto}.magnetic-letters{display:flex;align-items:center;justify-content:center}.magnetic-letters .m-letter{font-family:var(--font-primary);font-size:clamp(8rem,15vw,20rem);font-weight:700;letter-spacing:.02em;display:inline-block;will-change:transform;transition:text-shadow .3s ease,color .3s ease;color:var(--color-white);line-height:1;cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}.hero-combined-sticky{-webkit-user-select:none;-moz-user-select:none;user-select:none}.hero-combined-sticky ::selection{background:0 0}.magnetic-letters .m-letter:active{cursor:grabbing}.magnetic-letters .m-letter.near{text-shadow:0 0 30px rgba(139,106,32,.6),0 0 60px rgba(139,106,32,.3);color:var(--color-secondary)}.magnetic-sub{font-family:var(--font-secondary);font-size:clamp(.7rem,1.5vw,1.1rem);font-weight:400;letter-spacing:.35em;text-transform:uppercase;margin-top:2rem;color:var(--color-secondary);opacity:.7}.magnetic-location{font-family:var(--font-secondary);font-size:.75rem;letter-spacing:.5em;text-transform:uppercase;color:rgba(245,240,235,.4);margin-top:.75rem}.magnetic-cta{margin-top:1.5rem}.hero-scroll-hint{position:absolute;bottom:3vh;left:50%;transform:translateX(-50%);z-index:7;pointer-events:none;display:flex;flex-direction:column;align-items:center;gap:8px}.hero-scroll-hint span{font-family:var(--font-secondary);font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:rgba(139,106,32,.6)}.hero-scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,rgba(139,106,32,.6),transparent);animation:portalScrollPulse 2s ease infinite}.portal-video-wrap{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;background:#0C0B09}.portal-video-frame{width:100%;height:100%;object-fit:cover}.portal-mask{position:absolute;top:0;left:0;width:100%;height:100%;background:#0C0B09;pointer-events:none;z-index:3}.portal-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;pointer-events:none;z-index:4;border:2px solid rgba(139,106,32,.6);box-shadow:0 0 60px rgba(139,106,32,.4),0 0 120px rgba(139,106,32,.2),inset 0 0 60px rgba(139,106,32,.3)}.portal-text-left,.portal-text-right{position:absolute;top:50%;transform:translateY(-50%);font-family:var(--font-primary);font-size:clamp(48px,8vw,120px);font-weight:700;letter-spacing:.15em;color:var(--color-white);z-index:4;pointer-events:none;text-shadow:0 0 40px rgba(139,106,32,.3)}.portal-text-left{right:calc(50% + 18vw)}.portal-text-right{left:calc(50% + 18vw)}.portal-center-content{position:absolute;bottom:12vh;left:50%;transform:translateX(-50%);z-index:5;pointer-events:auto;display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center}.portal-logo{width:50px;height:50px;filter:brightness(0) invert(1) drop-shadow(0 0 30px rgba(139,106,32,.3))}.portal-subtitle{font-family:var(--font-secondary);font-size:clamp(.75rem,1.3vw,1rem);letter-spacing:.4em;text-transform:uppercase;color:var(--color-secondary);margin:0;white-space:nowrap}.portal-location{font-family:var(--font-secondary);font-size:.75rem;letter-spacing:.5em;text-transform:uppercase;color:rgba(245,240,235,.5);margin:0}.portal-scroll-hint{position:absolute;bottom:3vh;left:50%;transform:translateX(-50%);z-index:5;pointer-events:none;display:flex;flex-direction:column;align-items:center;gap:8px}.portal-scroll-hint span{font-family:var(--font-secondary);font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:rgba(139,106,32,.6)}.portal-scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,rgba(139,106,32,.6),transparent);animation:portalScrollPulse 2s ease infinite}@keyframes portalScrollPulse{0%,100%{opacity:.3;transform:scaleY(.5)}50%{opacity:1;transform:scaleY(1)}}@media (max-width:768px){.portal-hero{height:300vh}.portal-text-left,.portal-text-right{font-size:clamp(32px,6vw,60px)}.portal-text-left{right:calc(50% + 22vw)}.portal-text-right{left:calc(50% + 22vw)}.portal-center-content{bottom:15vh}}.svc-tabs-section{position:relative;z-index:2;border-radius:2rem 2rem 0 0;background-color:var(--color-dark)}.svc-tabs-padding{padding-top:5rem;padding-bottom:5rem}.svc-tabs-height{height:500vh}.svc-tabs-sticky{height:100vh;position:sticky;top:0}.svc-tabs-container{width:100%;max-width:120rem;margin:0 auto;height:100%}.svc-tabs-component{height:90vh;margin-top:5vh;display:grid;grid-template-columns:0.42fr 1fr;gap:1.5rem;padding:0 3.3%}.svc-tabs-left{border-radius:1.25rem;background-color:rgba(255,255,255,.05);display:flex;flex-direction:column;justify-content:space-between;padding:2rem}.svc-tabs-left-top{height:100%;position:relative;display:flex;flex-direction:column}.svc-tabs-header{margin-bottom:1rem}.svc-tab-content{width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;position:absolute;top:0;left:0;opacity:0;transition:opacity .5s ease;padding-top:3rem}.svc-tab-content.is-active{opacity:1}.svc-tab-number{font-family:var(--font-primary);font-size:1rem;color:var(--color-secondary);letter-spacing:3px;text-transform:uppercase;margin-bottom:1rem;display:block}.svc-tab-title{font-family:var(--font-primary);font-size:clamp(1.5rem,2.5vw,2.125rem);font-weight:500;line-height:1.1;color:var(--color-white);margin:0 0 1.5rem;letter-spacing:-.02em}.svc-tab-title em{font-style:italic;color:var(--color-secondary);font-weight:300}.svc-tab-line{width:100%;height:1px;background-color:rgba(255,255,255,.15);margin-bottom:1.5rem}.svc-tab-desc{font-family:var(--font-secondary);font-size:1rem;color:rgba(255,255,255,.7);line-height:1.6;margin:0 0 1.5rem}.svc-tab-tags{display:flex;flex-wrap:wrap;gap:.5rem}.svc-tabs-section .svc-tag{background:rgba(255,255,255,.08);color:rgba(255,255,255,.6);padding:.35rem .75rem;border-radius:2rem;font-size:.75rem;font-family:var(--font-secondary);letter-spacing:.5px}.svc-tabs-left-bottom{padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.08)}.svc-tabs-left-bottom .btn{width:100%;text-align:center}.svc-tabs-right{width:100%;height:100%;border-radius:1.25rem;position:relative;overflow:hidden}.svc-tab-visual{width:100%;height:100%;position:absolute;top:0;left:0;opacity:0;transform:translateY(8%);transition:opacity .6s ease,transform .6s ease;background-size:cover;background-position:center;border-radius:1.25rem;display:flex;align-items:flex-end;justify-content:flex-end;text-decoration:none}.svc-tab-visual.is-active{opacity:1;transform:translateY(0)}.svc-tab-visual::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.5) 0,transparent 40%);border-radius:1.25rem;pointer-events:none}.svc-tab-visual-cta{position:relative;z-index:2;font-family:var(--font-secondary);font-size:.9rem;color:var(--color-secondary);padding:1.5rem 2rem;letter-spacing:1px;transition:var(--transition-fast)}.svc-tab-visual:hover .svc-tab-visual-cta{letter-spacing:3px}.svc-tab-video{width:100%;height:100%;object-fit:cover;position:absolute;top:0;left:0}@media (max-width:768px){.svc-tabs-padding{padding-top:2rem;padding-bottom:0}.svc-tabs-height{height:600vh}.svc-tabs-component{grid-template-columns:1fr;grid-template-rows:1fr 1fr;height:95vh;margin-top:2.5vh;padding:0 1rem}.svc-tabs-left{padding:1.25rem;border-radius:1rem}.svc-tab-content{padding-top:2.5rem}.svc-tabs-right{border-radius:1rem;min-height:40vh}.svc-tab-visual{border-radius:1rem}.svc-tab-visual::after{border-radius:1rem}}@media (prefers-reduced-motion:reduce){*,::after,::before{animation-duration:0s!important;animation-iteration-count:1!important;transition-duration:0s!important;scroll-behavior:auto!important}}.hero-mobile-content{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;position:absolute;top:0;left:0;right:0;bottom:0;z-index:5;padding:2rem;background:linear-gradient(135deg,rgba(44,95,95,.95) 0,rgba(26,26,26,.9) 100%)}.hero-mobile-logo{width:70px;height:70px;margin-bottom:2rem;filter:brightness(0) invert(1) drop-shadow(0 0 40px rgba(139,106,32,.3)) drop-shadow(0 0 80px rgba(139,106,32,.15))}.hero-mobile-title{font-family:var(--font-primary);font-size:3rem;color:var(--color-white);letter-spacing:10px;font-weight:300;line-height:1;margin-bottom:.75rem}.hero-mobile-title span{display:block;font-size:1.1rem;letter-spacing:14px;color:var(--color-secondary);margin-top:.5rem}.hero-mobile-subtitle{font-family:var(--font-secondary);font-size:1.05rem;color:rgba(255,255,255,.85);margin-bottom:.75rem;font-style:italic;line-height:1.6}.hero-mobile-location{font-size:.85rem;color:var(--color-secondary);letter-spacing:2px;text-transform:uppercase;margin-bottom:2.5rem}@keyframes heroPulse{0%,100%{box-shadow:0 0 0 0 rgba(139,106,32,.4)}50%{box-shadow:0 0 0 12px rgba(139,106,32,0)}}.hero-mobile-content .btn-primary{animation:heroPulse 3s ease-in-out infinite}@media (min-width:768px){.hero-mobile-title{font-size:5rem;letter-spacing:16px}.hero-mobile-title span{font-size:1.5rem;letter-spacing:20px}.hero-mobile-subtitle{font-size:1.25rem}.hero-mobile-logo{width:90px;height:90px}}.reveal-baseline{font-family:var(--font-secondary);font-size:1rem;color:rgba(255,255,255,.8);font-style:italic;margin-bottom:1.5rem;letter-spacing:1px}@media (min-width:768px){.reveal-baseline{font-size:1.15rem}}.cta-intermediate{padding:4rem 0;text-align:center;background:linear-gradient(135deg,var(--color-cream) 0,#f0ebe3 50%,var(--color-cream) 100%);position:relative}.cta-intermediate--dark{background:linear-gradient(135deg,var(--color-primary) 0,#1e4a4a 50%,var(--color-primary) 100%)}.cta-intermediate-text{font-family:var(--font-primary);font-size:clamp(1.75rem,4vw,2.5rem);margin-bottom:1.5rem;color:var(--color-dark);line-height:1.3;letter-spacing:.5px}.cta-intermediate--dark .cta-intermediate-text{color:var(--color-white)}@media (min-width:768px){.cta-intermediate{padding:5rem 0}.cta-intermediate-text{font-size:clamp(2rem,4vw,3rem)}}@keyframes floatingPulse{0%,100%{box-shadow:0 6px 30px rgba(139,106,32,.3)}50%{box-shadow:0 6px 40px rgba(139,106,32,.55)}}.floating-cta{position:fixed;bottom:6rem;right:2rem;z-index:998;background:var(--color-secondary);color:var(--color-dark);font-family:var(--font-primary);font-weight:600;font-size:.9rem;letter-spacing:1px;padding:1rem 2rem;border-radius:50px;border:none;cursor:pointer;text-decoration:none;display:flex;align-items:center;gap:.5rem;box-shadow:0 6px 30px rgba(139,106,32,.3);opacity:0;transform:translateY(20px) scale(.9);pointer-events:none;transition:opacity .4s cubic-bezier(.25,.46,.45,.94),transform .4s cubic-bezier(.25,.46,.45,.94),background .3s ease,box-shadow .3s ease}.floating-cta.visible{opacity:1;transform:translateY(0) scale(1);pointer-events:auto;animation:floatingPulse 3s ease-in-out infinite}.floating-cta:hover{background:#b8942f;transform:translateY(-3px) scale(1.05);box-shadow:0 12px 40px rgba(139,106,32,.5);animation:none}@media (max-width:767px){.floating-cta{display:none}}.mobile-sticky-cta{display:none}@media (max-width:767px){.mobile-sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:998;background:rgba(44,95,95,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:.75rem 1rem;padding-bottom:max(.75rem,env(safe-area-inset-bottom));display:none;border-top:1px solid rgba(139,106,32,.2)}.mobile-sticky-cta.visible{display:block}.mobile-sticky-cta .btn{display:block;width:100%;text-align:center;font-size:1rem;font-weight:600;padding:.875rem 1.5rem}}.cursor-dot{display:none}.cursor-ring{display:none}@media (hover:hover) and (pointer:fine){body{cursor:none}[role=button],a,button,input,label,select,textarea{cursor:none}.cursor-dot{display:block;position:fixed;top:0;left:0;width:8px;height:8px;background:var(--color-secondary);border-radius:50%;pointer-events:none;z-index:10000;transform:translate(-50%,-50%);transition:width .3s cubic-bezier(.25,.46,.45,.94),height .3s cubic-bezier(.25,.46,.45,.94),background .3s cubic-bezier(.25,.46,.45,.94)}.cursor-ring{display:block;position:fixed;top:0;left:0;width:40px;height:40px;border:1.5px solid var(--color-secondary);border-radius:50%;pointer-events:none;z-index:10000;opacity:.5;transform:translate(-50%,-50%);transition:width .25s cubic-bezier(.25,.46,.45,.94),height .25s cubic-bezier(.25,.46,.45,.94),opacity .25s ease,border-color .25s ease}.cursor-dot.hovering{width:50px;height:50px;background:rgba(139,106,32,.15);mix-blend-mode:difference}.cursor-ring.hovering{width:60px;height:60px;opacity:.8;border-color:var(--color-secondary)}}.scroll-progress{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--color-secondary),#e8c547);z-index:10001;width:0%;pointer-events:none}.clients-bar{padding:3rem 0;background:var(--color-cream);text-align:center}.clients-bar-title{font-family:var(--font-secondary);font-size:.85rem;letter-spacing:3px;text-transform:uppercase;color:#999;margin-bottom:2rem}.clients-logos{display:flex;align-items:center;justify-content:center;gap:3rem;flex-wrap:wrap;opacity:.4;filter:grayscale(100%);transition:opacity .4s ease,filter .4s ease;padding:0 1.25rem}.clients-logos:hover{opacity:.7;filter:grayscale(50%)}@media print{.floating-cta,.footer,.navbar,.skip-link,.theme-toggle,.video-scroll-section,footer,nav{display:none!important}body{background:#fff!important;color:#000!important}*{box-shadow:none!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important}a[href]::after{content:" (" attr(href) ")";font-size:.85em;color:#555}a[href^="#"]::after,a[href^=javascript]::after{content:""}}.section-title,.section-title-center,.portfolio-intro-title{color:#2C5F5F}.feature-tag{background:#2C5F5F}@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.001ms !important;animation-iteration-count:1 !important;transition-duration:0.001ms !important;scroll-behavior:auto !important}html{scroll-behavior:auto !important}video[autoplay]{display:none}.splash-cursor,#splashCursor,#leavesCanvas,#grainientCanvas,#magneticGlow{display:none !important}}@media (prefers-contrast:more){:root{--color-secondary:#8B6A20 !important}.text-gold,.section-label{color:#8B6A20 !important}}
/* === A11y polish 2026-05-04 — fix contrast WCAG AA sur fonds clairs === */
/* Or #8B6A20 sur cream 1.97-2.08 (fail) → or fonce #8B6A20 (passes 5.5+) */
.about-content .section-label,.about-content .text-gold,.zp-caption .container-scroll-kicker,.zp-caption .zp-title em{color:#8B6A20 !important}
/* zp-title cream sur cream voile (1.13 fail) → noir profond + ombre cream pour rester sur DA */
.zp-caption .zp-title{color:#f5efe3 !important}
.zp-caption .container-scroll-kicker{color:#8B6A20 !important;font-weight:600}