.vertical-loop-container{align-items:center;max-width:100%;height:100vh;display:flex;overflow:hidden}.vertical-loop-content{white-space:nowrap;will-change:transform;backface-visibility:hidden;animation:40s linear infinite verticalScroll;animation-play-state:running!important}@keyframes verticalScroll{0%{transform:translateY(0)translateZ(0)}to{transform:translateY(-50%)translateZ(0)}}
@keyframes drawLine{0%{opacity:0;width:0}20%{opacity:.6}to{opacity:.6;width:100%}}.accent-line{background:var(--accent);border-radius:1px;height:2px;animation:1s cubic-bezier(.4,0,.2,1) forwards drawLine}.accent-line-desktop{height:2px}
.philosophy-container{background:var(--background);color:var(--foreground);width:100%;max-width:100vw;min-height:250vh;position:relative;overflow:hidden}.philosophy-blocks-wrapper{contain:layout style paint;position:relative}.philosophy-block{will-change:transform,opacity;backface-visibility:hidden;perspective:1000px;flex-direction:column;justify-content:center;align-items:center;min-height:60vh;padding:2rem 1.5rem;display:flex;transform:translateZ(0)}@media (min-width:640px){.philosophy-block{min-height:70vh;padding:2.5rem 3rem}}@media (min-width:1024px){.philosophy-block{min-height:80vh;padding:3rem 4rem}}.philosophy-headline{font-family:var(--font-heading);color:var(--foreground);text-align:center;margin-bottom:2rem;font-size:32px;font-weight:400;line-height:1.2}@media (min-width:640px){.philosophy-headline{margin-bottom:2.5rem;font-size:40px}}@media (min-width:1024px){.philosophy-headline{margin-bottom:3rem;font-size:48px}}.philosophy-body{font-family:var(--font-body);color:var(--foreground);text-align:center;max-width:800px;margin:0 auto;font-size:16px;font-weight:400;line-height:1.7}@media (min-width:640px){.philosophy-body{font-size:18px;line-height:1.8}}@media (min-width:1024px){.philosophy-body{max-width:900px;font-size:20px;line-height:1.8}}.philosophy-highlight{color:var(--accent);font-weight:500}@media (max-width:639px){.philosophy-container{min-height:auto}.philosophy-block{will-change:auto;min-height:auto;padding:4rem 1.5rem;opacity:1!important;transform:translateY(0)scale(1)!important}}@media (prefers-reduced-motion:reduce){.philosophy-block{will-change:auto;opacity:1!important;transition:none!important;animation:none!important;transform:translateY(0)scale(1)!important}}
.services-modal-overlay{-webkit-backdrop-filter:blur();z-index:9999;background:0 0;justify-content:center;align-items:center;padding:1rem;animation:.5s cubic-bezier(.4,0,.2,1) forwards modalOverlayFadeIn;display:flex;position:fixed;inset:0}@keyframes modalOverlayFadeIn{0%{-webkit-backdrop-filter:blur();background:0 0}to{-webkit-backdrop-filter:blur(12px);background:#000000d9}}.services-modal-content{background:var(--background);transform-origin:50%;border-radius:24px;width:100%;max-width:900px;max-height:90vh;padding:2rem;animation:.6s cubic-bezier(.16,1,.3,1) forwards modalContentSlideIn;position:relative;overflow-y:auto;box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #ff88001a,0 0 80px -20px #ff880026}@keyframes modalContentSlideIn{0%{opacity:0;filter:blur(4px);transform:scale(.92)translateY(40px)rotateX(8deg)}50%{filter:blur()}to{opacity:1;filter:blur();transform:scale(1)translateY(0)rotateX(0)}}@media (min-width:640px){.services-modal-content{border-radius:28px;padding:3rem}}@media (min-width:1024px){.services-modal-content{padding:3.5rem}}.services-modal-close{color:var(--foreground);cursor:pointer;z-index:10;opacity:0;background:#0000000d;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:28px;font-weight:300;line-height:1;transition:all .4s cubic-bezier(.16,1,.3,1);animation:.4s cubic-bezier(.16,1,.3,1) .3s forwards closeButtonAppear;display:flex;position:absolute;top:1rem;right:1rem;transform:scale(.8)rotate(-90deg)}@keyframes closeButtonAppear{0%{opacity:0;transform:scale(.8)rotate(-90deg)}to{opacity:1;transform:scale(1)rotate(0)}}.services-modal-close:hover{background:var(--accent);color:#fff;transform:scale(1.1)rotate(90deg);box-shadow:0 4px 16px #ff88004d}@media (min-width:640px){.services-modal-close{width:48px;height:48px;font-size:32px;top:1.5rem;right:1.5rem}}.services-modal-header{text-align:center;opacity:0;margin-bottom:2rem;padding-top:1rem;animation:.5s cubic-bezier(.16,1,.3,1) .2s forwards modalHeaderFadeIn}@keyframes modalHeaderFadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media (min-width:640px){.services-modal-header{margin-bottom:2.5rem;padding-top:0}}.services-modal-title{font-family:var(--font-heading);color:var(--foreground);margin:0 0 .75rem;font-size:32px;font-weight:400;display:inline-block;position:relative}.services-modal-title:after{content:"";background:var(--accent);border-radius:2px;width:60px;height:3px;animation:.4s cubic-bezier(.16,1,.3,1) .5s forwards underlineGrow;position:absolute;bottom:-8px;left:50%;transform:translate(-50%)scaleX(0)}@keyframes underlineGrow{0%{transform:translate(-50%)scaleX(0)}to{transform:translate(-50%)scaleX(1)}}@media (min-width:640px){.services-modal-title{font-size:40px}.services-modal-title:after{width:80px;bottom:-10px}}@media (min-width:1024px){.services-modal-title{font-size:48px}.services-modal-title:after{width:100px;height:4px}}.services-modal-subtitle{font-family:var(--font-body);color:#0009;margin:1.5rem 0 0;font-size:14px;line-height:1.6}@media (min-width:640px){.services-modal-subtitle{margin-top:1.75rem;font-size:16px}}.services-modal-grid{grid-template-columns:1fr;gap:1rem;display:grid}@media (min-width:640px){.services-modal-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem}}@media (min-width:1024px){.services-modal-grid{gap:1.5rem}}.services-modal-item{opacity:0;background:#00000005;border:1px solid #0000000f;border-radius:16px;align-items:flex-start;gap:1rem;padding:1.25rem;transition:all .3s;animation:.6s cubic-bezier(.16,1,.3,1) forwards serviceItemFadeIn;display:flex;transform:translateY(30px)scale(.95)}@keyframes serviceItemFadeIn{0%{opacity:0;filter:blur(2px);transform:translateY(30px)scale(.95)}60%{filter:blur()}to{opacity:1;filter:blur();transform:translateY(0)scale(1)}}.services-modal-item:first-child{animation-delay:.3s}.services-modal-item:nth-child(2){animation-delay:.38s}.services-modal-item:nth-child(3){animation-delay:.46s}.services-modal-item:nth-child(4){animation-delay:.54s}.services-modal-item:nth-child(5){animation-delay:.62s}.services-modal-item:nth-child(6){animation-delay:.7s}.services-modal-item:nth-child(7){animation-delay:.78s}.services-modal-item:hover{background:#ff88000d;border-color:#f803;transform:translateY(-2px);box-shadow:0 8px 24px #ff88001a}@media (min-width:640px){.services-modal-item{gap:1.25rem;padding:1.5rem}}.services-modal-icon{background:#ff88001a;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:28px;transition:all .3s;display:flex}.services-modal-item:hover .services-modal-icon{background:var(--accent);transform:scale(1.1)}@media (min-width:640px){.services-modal-icon{width:56px;height:56px;font-size:32px}}.services-modal-item-content{flex:1;min-width:0}.services-modal-item-title{font-family:var(--font-heading);color:var(--foreground);margin:0 0 .35rem;font-size:18px;font-weight:400;line-height:1.3}@media (min-width:640px){.services-modal-item-title{font-size:20px}}.services-modal-item-description{font-family:var(--font-body);color:#0009;margin:0;font-size:13px;line-height:1.5}@media (min-width:640px){.services-modal-item-description{font-size:14px}}.services-modal-footer{text-align:center;opacity:0;border-top:1px solid #00000014;flex-direction:column;align-items:center;gap:1rem;margin-top:2rem;padding-top:2rem;animation:.5s cubic-bezier(.16,1,.3,1) .9s forwards modalFooterFadeIn;display:flex}@keyframes modalFooterFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (min-width:640px){.services-modal-footer{text-align:left;flex-direction:row;justify-content:space-between;margin-top:2.5rem;padding-top:2.5rem}}.services-modal-footer-text{font-family:var(--font-body);color:#0009;margin:0;font-size:14px}@media (min-width:640px){.services-modal-footer-text{font-size:15px}}.services-modal-cta{background:var(--accent);color:#fff;font-family:var(--font-body);border-radius:12px;align-items:center;gap:.5rem;padding:.875rem 1.75rem;font-size:14px;font-weight:500;text-decoration:none;transition:all .3s;display:inline-flex;box-shadow:0 4px 12px #ff88004d}.services-modal-cta:hover{background:#e67700;transform:translateY(-2px);box-shadow:0 8px 20px #f806}.services-modal-cta:after{content:"→";transition:transform .3s}.services-modal-cta:hover:after{transform:translate(4px)}@media (min-width:640px){.services-modal-cta{padding:1rem 2rem;font-size:15px}}.services-modal-content::-webkit-scrollbar{width:8px}.services-modal-content::-webkit-scrollbar-track{background:0 0}.services-modal-content::-webkit-scrollbar-thumb{background:#00000026;border-radius:4px}.services-modal-content::-webkit-scrollbar-thumb:hover{background:#00000040}.services-button-wrapper{justify-content:center;width:100%;margin-top:-2rem;padding:0 0 4rem;display:flex}@media (min-width:640px){.services-button-wrapper{margin-top:-3rem;padding:0 0 5rem}}@media (min-width:1024px){.services-button-wrapper{margin-top:-4rem;padding:0 0 6rem}}.services-button{color:var(--foreground);font-family:var(--font-heading);border:2px solid var(--foreground);cursor:pointer;isolation:isolate;background:0 0;border-radius:12px;align-items:center;gap:.75rem;padding:1rem 1.75rem;font-size:20px;font-weight:400;transition:all .3s;display:inline-flex;position:relative;overflow:hidden}.services-button:before{content:"";background:var(--accent);z-index:-1;width:0;height:100%;transition:width .3s;position:absolute;top:0;left:0}.services-button:hover{color:#fff;border-color:var(--accent)}.services-button:hover:before{width:100%}.services-button-arrow{transition:transform .3s;display:inline-block}.services-button:hover .services-button-arrow{transform:translate(4px)}@media (min-width:640px){.services-button{gap:1rem;padding:1.25rem 2rem;font-size:24px}}@media (min-width:1024px){.services-button{padding:1.5rem 2.5rem;font-size:28px}}
.leistungen-container{background:var(--background);color:var(--foreground);flex-direction:column;justify-content:center;align-items:center;width:100%;max-width:100vw;min-height:250vh;padding:4rem 1.5rem;display:flex;position:relative;overflow:clip visible}@media (min-width:640px){.leistungen-container{padding:5rem 3rem}}@media (min-width:1024px){.leistungen-container{padding:6rem 4rem}.leistungen-blocks-wrapper{padding-right:2rem}}.leistungen-blocks-wrapper{flex-direction:column;align-items:flex-start;width:100%;max-width:1000px;padding-right:1rem;display:flex;position:relative;overflow:visible}.leistungen-headline{font-family:var(--font-heading);color:var(--foreground);text-align:left;overflow-wrap:break-word;word-wrap:break-word;-webkit-hyphens:none;hyphens:none;max-width:100%;margin:0;padding-bottom:3rem;font-size:40px;font-weight:400;line-height:1.2;display:inline-block;position:relative}.leistungen-headline:after{content:"";background:var(--accent);width:80px;height:2px;position:absolute;bottom:2rem;left:0}@media (min-width:640px){.leistungen-headline{padding-bottom:4rem;font-size:56px}.leistungen-headline:after{width:100px;bottom:3rem}}@media (min-width:1024px){.leistungen-headline{padding-bottom:5rem;font-size:72px}.leistungen-headline:after{width:120px;bottom:4rem}}.service-item{will-change:transform,opacity;backface-visibility:hidden;perspective:1000px;grid-template-columns:minmax(auto,30%) minmax(0,70%);align-items:start;gap:2rem;width:100%;max-width:100%;min-height:100vh;padding:3rem 0;display:grid;overflow:visible;transform:translateZ(0)}@media (min-width:640px){.service-item{gap:3rem;padding:4rem 0}}@media (min-width:1024px){.service-item{gap:4rem;padding:5rem 0}}.service-number{font-family:var(--font-heading);color:var(--accent);text-align:left;flex-shrink:0;min-width:0;font-size:64px;font-weight:400;line-height:1}@media (min-width:640px){.service-number{font-size:90px}}@media (min-width:1024px){.service-number{font-size:120px}}.service-content{overflow-wrap:break-word;word-wrap:break-word;-webkit-hyphens:none;hyphens:none;flex-direction:column;gap:1rem;min-width:0;max-width:100%;display:flex}@media (min-width:1024px){.service-content{gap:1.5rem}}.service-headline{font-family:var(--font-heading);color:var(--foreground);overflow-wrap:break-word;word-wrap:break-word;-webkit-hyphens:none;hyphens:none;max-width:100%;margin:0;font-size:24px;font-weight:400;line-height:1.2}@media (min-width:640px){.service-headline{font-size:32px}}@media (min-width:1024px){.service-headline{font-size:40px}}.service-tagline{font-family:var(--font-body);color:var(--accent);overflow-wrap:break-word;word-wrap:break-word;-webkit-hyphens:none;hyphens:none;max-width:100%;margin:0;font-size:14px;font-weight:500;line-height:1.6}@media (min-width:640px){.service-tagline{font-size:16px}}@media (min-width:1024px){.service-tagline{font-size:18px}}.service-description{font-family:var(--font-body);color:var(--foreground);overflow-wrap:break-word;word-wrap:break-word;-webkit-hyphens:none;hyphens:none;max-width:100%;margin:0;font-size:14px;font-weight:400;line-height:1.7}@media (min-width:640px){.service-description{font-size:16px;line-height:1.8}}@media (min-width:1024px){.service-description{font-size:18px;line-height:1.8}}@media (max-width:639px){.leistungen-container{min-height:auto}.service-item{will-change:auto;text-align:left;grid-template-columns:1fr;gap:1rem;min-height:auto;padding:3rem 0}.service-number{text-align:left}.service-item{opacity:1!important;transform:translateY(0)translate(0)scale(1)!important}}@media (prefers-reduced-motion:reduce){.service-item{will-change:auto;opacity:1!important;transition:none!important;animation:none!important;transform:translateY(0)translate(0)scale(1)!important}}
.testimonials-section{background:linear-gradient(#fafafa 0%,#f5f5f5 100%);padding:100px 24px;position:relative;overflow:hidden}@media (min-width:768px){.testimonials-section{padding:120px 48px}}@media (min-width:1024px){.testimonials-section{padding:140px 64px}}.testimonials-container{max-width:900px;margin:0 auto}.testimonials-header{text-align:center;margin-bottom:48px}@media (min-width:768px){.testimonials-header{margin-bottom:64px}}.testimonials-label{font-family:var(--font-body);color:var(--accent);text-transform:uppercase;letter-spacing:.15em;margin-bottom:16px;font-size:12px;font-weight:600;display:inline-block}@media (min-width:768px){.testimonials-label{font-size:13px}}.testimonials-title{font-family:var(--font-heading);color:var(--foreground);margin:0;font-size:clamp(28px,5vw,42px);line-height:1.2}.testimonials-carousel{text-align:center;position:relative}.testimonials-quote-icon{width:48px;height:48px;color:var(--accent);opacity:.6;margin:0 auto 32px}@media (min-width:768px){.testimonials-quote-icon{width:56px;height:56px;margin-bottom:40px}}.testimonials-quote-icon svg{width:100%;height:100%}.testimonials-slider-wrapper{height:300px;position:relative;overflow:hidden}@media (min-width:640px){.testimonials-slider-wrapper{height:260px}}@media (min-width:768px){.testimonials-slider-wrapper{height:200px}}@media (min-width:1024px){.testimonials-slider-wrapper{height:180px}}.testimonials-slider{height:100%;transition:transform .6s cubic-bezier(.4,0,.2,1);display:flex}.testimonials-slide{box-sizing:border-box;flex:0 0 100%;justify-content:center;align-items:flex-start;width:100%;padding:0 20px;display:flex}.testimonials-quote{font-family:var(--font-body);color:var(--foreground);scrollbar-width:none;-ms-overflow-style:none;max-width:800px;max-height:100%;margin:0;font-size:clamp(15px,2.5vw,18px);font-weight:400;line-height:1.8;overflow-y:auto}.testimonials-quote::-webkit-scrollbar{display:none}.testimonials-author-wrapper{z-index:10;flex-direction:column;align-items:center;gap:20px;min-height:100px;margin-top:32px;display:flex;position:relative}@media (min-width:768px){.testimonials-author-wrapper{min-height:90px;margin-top:40px}}.testimonials-author{flex-direction:column;gap:6px;animation:.4s ease-out testimonialFadeIn;display:flex}@keyframes testimonialFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.testimonials-author-name{font-family:var(--font-heading);color:var(--foreground);font-size:18px}@media (min-width:768px){.testimonials-author-name{font-size:20px}}.testimonials-author-info{font-family:var(--font-body);color:#00000080;font-size:14px}@media (min-width:768px){.testimonials-author-info{font-size:15px}}.testimonials-project-link{background:var(--accent);color:#fff;font-family:var(--font-body);border-radius:30px;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:14px;font-weight:500;text-decoration:none;transition:all .3s;animation:.4s ease-out .1s both testimonialFadeIn;display:inline-flex}.testimonials-project-link:hover{background:#e67700;transform:translateY(-2px);box-shadow:0 6px 20px #ff880059}.testimonials-project-link:active{transform:translateY(0)}.testimonials-project-link svg{transition:transform .3s}.testimonials-project-link:hover svg{transform:translate(4px)}@media (min-width:768px){.testimonials-project-link{padding:14px 28px;font-size:15px}}.testimonials-nav{justify-content:center;gap:16px;margin-top:32px;display:flex}@media (min-width:768px){.testimonials-nav{pointer-events:none;justify-content:space-between;margin-top:0;padding:0;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}}.testimonials-nav-btn{width:44px;height:44px;color:var(--foreground);cursor:pointer;pointer-events:auto;background:#fff;border:1px solid #0000001a;border-radius:50%;justify-content:center;align-items:center;transition:all .3s;display:flex}.testimonials-nav-btn:hover{border-color:var(--accent);color:var(--accent);transform:scale(1.05)}.testimonials-nav-btn:active{transform:scale(.95)}@media (min-width:768px){.testimonials-nav-btn{width:48px;height:48px}.testimonials-nav-prev{margin-left:-60px}.testimonials-nav-next{margin-right:-60px}}@media (min-width:1024px){.testimonials-nav-prev{margin-left:-80px}.testimonials-nav-next{margin-right:-80px}}.testimonials-dots{justify-content:center;gap:10px;margin-top:32px;display:flex}@media (min-width:768px){.testimonials-dots{margin-top:40px}}.testimonials-dot{cursor:pointer;background:#00000026;border:none;border-radius:50%;width:10px;height:10px;padding:0;transition:all .3s}.testimonials-dot:hover{background:#0000004d}.testimonials-dot.active{background:var(--accent);transform:scale(1.2)}.testimonials-section:before{content:"";background:linear-gradient(90deg,#0000 0%,#00000014 20% 80%,#0000 100%);height:1px;position:absolute;top:0;left:0;right:0}.testimonials-section:after{content:"";background:linear-gradient(90deg,#0000 0%,#00000014 20% 80%,#0000 100%);height:1px;position:absolute;bottom:0;left:0;right:0}
.portfolio-container{background:var(--background);color:var(--foreground);flex-direction:column;align-items:center;width:100%;padding:6rem 1.5rem;display:flex;position:relative;overflow:hidden}@media (min-width:640px){.portfolio-container{padding:8rem 3rem}}@media (min-width:1024px){.portfolio-container{padding:10rem 6rem}}.portfolio-content{flex-direction:column;align-items:center;width:100%;max-width:1200px;display:flex}.portfolio-main-headline{font-family:var(--font-heading);text-align:center;margin:0;font-size:36px;font-weight:400;line-height:1.2;display:inline-block;position:relative}.portfolio-main-headline:after{content:"";background:var(--accent);border-radius:2px;width:60px;height:3px;position:absolute;bottom:-8px;left:50%;transform:translate(-50%)}@media (min-width:640px){.portfolio-main-headline{font-size:48px}.portfolio-main-headline:after{width:80px;bottom:-10px}}@media (min-width:1024px){.portfolio-main-headline{font-size:56px}.portfolio-main-headline:after{width:100px;height:4px}}.portfolio-subtitle{font-family:var(--font-body);color:#0009;text-align:center;margin:1.5rem 0 0;font-size:15px;font-weight:400;line-height:1.6}@media (min-width:640px){.portfolio-subtitle{font-size:17px}}@media (min-width:1024px){.portfolio-subtitle{font-size:18px}}.portfolio-showcase-list{flex-direction:column;gap:2rem;width:100%;margin-top:3rem;display:flex}@media (min-width:640px){.portfolio-showcase-list{gap:2.5rem;margin-top:4rem}}@media (min-width:1024px){.portfolio-showcase-list{gap:3rem;margin-top:5rem}}.portfolio-showcase-item{aspect-ratio:16/10;width:100%;color:inherit;border-radius:12px;text-decoration:none;transition:box-shadow .4s cubic-bezier(.4,0,.2,1),transform .4s cubic-bezier(.4,0,.2,1);display:block;position:relative;overflow:hidden;box-shadow:0 4px 24px #0000001a}@media (min-width:640px){.portfolio-showcase-item{aspect-ratio:16/9;border-radius:16px}}.portfolio-showcase-item:hover{transform:translateY(-4px);box-shadow:0 16px 48px #0000002e}.portfolio-showcase-item--contain{background:#f5f5f5}.portfolio-showcase-media{position:absolute;inset:0;overflow:hidden}.portfolio-showcase-media img,.portfolio-showcase-video{object-fit:cover;width:100%;height:100%;transition:transform .6s cubic-bezier(.4,0,.2,1)}.portfolio-showcase-item:hover .portfolio-showcase-media img,.portfolio-showcase-item:hover .portfolio-showcase-video{transform:scale(1.04)}.portfolio-showcase-overlay{text-align:center;z-index:2;background:linear-gradient(#0000 0%,#00000059 40%,#000000bf 100%);flex-direction:column;align-items:center;gap:.5rem;padding:2rem 1.5rem;display:flex;position:absolute;bottom:0;left:0;right:0}@media (min-width:640px){.portfolio-showcase-overlay{gap:.6rem;padding:2.5rem 2rem}}@media (min-width:1024px){.portfolio-showcase-overlay{gap:.75rem;padding:3rem 2.5rem}}.portfolio-showcase-category{font-family:var(--font-body);color:#fff;text-transform:uppercase;letter-spacing:.12em;background:var(--accent);border-radius:4px;padding:.35rem .75rem;font-size:11px;font-weight:600}@media (min-width:640px){.portfolio-showcase-category{padding:.4rem .85rem;font-size:12px}}@media (min-width:1024px){.portfolio-showcase-category{font-size:13px}}.portfolio-showcase-name{font-family:var(--font-heading);color:#fff;margin:0;font-size:28px;font-weight:400;line-height:1.2}@media (min-width:640px){.portfolio-showcase-name{font-size:36px}}@media (min-width:1024px){.portfolio-showcase-name{font-size:48px}}.portfolio-showcase-link{font-family:var(--font-body);color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:0;letter-spacing:.02em;background:#ffffff1f;border:1px solid #fff3;border-radius:20px;align-items:center;gap:.5rem;margin-top:.5rem;padding:.5rem 1.1rem;font-size:13px;font-weight:500;transition:opacity .35s,transform .35s,background .3s;display:inline-flex;transform:translateY(8px)}.portfolio-showcase-item:hover .portfolio-showcase-link{opacity:1;transform:translateY(0)}.portfolio-showcase-link svg{transition:transform .3s}.portfolio-showcase-item:hover .portfolio-showcase-link svg{transform:translate(3px)}@media (min-width:640px){.portfolio-showcase-link{margin-top:.75rem;padding:.55rem 1.25rem;font-size:14px}}.portfolio-cta-wrapper{justify-content:center;width:100%;margin-top:3rem;display:flex}@media (min-width:640px){.portfolio-cta-wrapper{margin-top:4rem}}.portfolio-cta-button{font-family:var(--font-body);color:var(--foreground);letter-spacing:.02em;border:1.5px solid #00000026;border-radius:8px;align-items:center;gap:.75rem;padding:1rem 2rem;font-size:15px;font-weight:500;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex}@media (min-width:640px){.portfolio-cta-button{padding:1.1rem 2.25rem;font-size:16px}}.portfolio-cta-button:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px #ff88004d}.portfolio-cta-button svg{transition:transform .3s}.portfolio-cta-button:hover svg{transform:translate(4px)}
.zusammenarbeit-container{background:var(--background);color:var(--foreground);flex-direction:column;justify-content:center;align-items:center;width:100%;max-width:100vw;min-height:100vh;padding:4rem 1.5rem;display:flex;position:relative;overflow:hidden}@media (min-width:640px){.zusammenarbeit-container{padding:5rem 3rem}}@media (min-width:1024px){.zusammenarbeit-container{padding:6rem}}.zusammenarbeit-content{flex-direction:column;align-items:flex-start;width:100%;max-width:900px;display:flex}.zusammenarbeit-section-headline{font-family:var(--font-heading);color:var(--foreground);margin:0;padding-bottom:3rem;font-size:40px;font-weight:400;line-height:1.2;display:inline-block;position:relative}.zusammenarbeit-section-headline:after{content:"";background:var(--accent);width:80px;height:2px;position:absolute;bottom:2rem;left:0}@media (min-width:640px){.zusammenarbeit-section-headline{padding-bottom:4rem;font-size:56px}.zusammenarbeit-section-headline:after{width:100px;bottom:2.5rem}}@media (min-width:1024px){.zusammenarbeit-section-headline{padding-bottom:5rem;font-size:72px}.zusammenarbeit-section-headline:after{width:120px;bottom:3rem}}.zusammenarbeit-list{flex-direction:column;gap:3rem;width:100%;display:flex}@media (min-width:640px){.zusammenarbeit-list{gap:3.5rem}}@media (min-width:1024px){.zusammenarbeit-list{gap:4rem}}.zusammenarbeit-item{flex-direction:column;gap:.75rem;display:flex}@media (min-width:1024px){.zusammenarbeit-item{gap:1rem}}.zusammenarbeit-headline{font-family:var(--font-heading);color:var(--foreground);margin:0;font-size:24px;font-weight:400;line-height:1.2}@media (min-width:640px){.zusammenarbeit-headline{font-size:32px}}@media (min-width:1024px){.zusammenarbeit-headline{font-size:40px}}.zusammenarbeit-description{font-family:var(--font-body);color:var(--foreground);margin:0;font-size:16px;font-weight:400;line-height:1.7}@media (min-width:640px){.zusammenarbeit-description{font-size:18px;line-height:1.8}}@media (min-width:1024px){.zusammenarbeit-description{font-size:20px;line-height:1.8}}.zusammenarbeit-cta{font-family:var(--font-body);color:var(--accent);margin:2rem 0 0;font-size:16px;font-weight:400;line-height:1.6}@media (min-width:640px){.zusammenarbeit-cta{margin-top:2.5rem;font-size:18px}}@media (min-width:1024px){.zusammenarbeit-cta{margin-top:3rem;font-size:20px}}
.project-teaser-container{background:var(--background);color:var(--foreground);flex-direction:column;justify-content:center;align-items:center;width:100%;max-width:100vw;padding:6rem 0;display:flex;position:relative;overflow:hidden}@media (min-width:640px){.project-teaser-container{padding:8rem 0}}@media (min-width:1024px){.project-teaser-container{padding:10rem 0}}.project-teaser-content{flex-direction:column;align-items:center;width:100%;display:flex}.project-teaser-headline{text-align:center;flex-direction:column;align-items:center;gap:.75rem;margin:0;padding:0 1.5rem 3rem;display:flex}@media (min-width:640px){.project-teaser-headline{padding-bottom:4rem}}@media (min-width:1024px){.project-teaser-headline{padding-bottom:5rem}}.project-teaser-headline-large{font-family:var(--font-heading);color:var(--foreground);font-size:36px;font-weight:400;line-height:1.2;display:inline-block;position:relative}.project-teaser-headline-large:after{content:"";background:var(--accent);border-radius:2px;width:60px;height:3px;position:absolute;bottom:-8px;left:50%;transform:translate(-50%)}@media (min-width:640px){.project-teaser-headline-large{font-size:48px}.project-teaser-headline-large:after{width:80px;bottom:-10px}}@media (min-width:1024px){.project-teaser-headline-large{font-size:56px}.project-teaser-headline-large:after{width:100px;height:4px}}.project-teaser-headline-small{font-family:var(--font-body);color:#0009;margin-top:1rem;font-size:15px;font-weight:400;line-height:1.6}@media (min-width:640px){.project-teaser-headline-small{font-size:17px}}@media (min-width:1024px){.project-teaser-headline-small{font-size:18px}}.marquee-container{width:100%;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000 0%,#000 8% 92%,#0000 100%);mask-image:linear-gradient(90deg,#0000 0%,#000 8% 92%,#0000 100%)}.marquee-track{will-change:transform;gap:1.25rem;width:max-content;animation:35s linear infinite marquee;display:flex}.marquee-container:hover .marquee-track{animation-play-state:paused}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}.marquee-item{cursor:pointer;background:#fafafa;border-radius:12px;flex-shrink:0;width:280px;height:200px;transition:transform .4s cubic-bezier(.4,0,.2,1),box-shadow .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 4px 20px #00000014}@media (min-width:640px){.marquee-item{border-radius:14px;width:360px;height:240px}.marquee-track{gap:1.5rem}}@media (min-width:1024px){.marquee-item{border-radius:16px;width:420px;height:280px}.marquee-track{gap:2rem}}.marquee-item:hover{transform:translateY(-6px)scale(1.02);box-shadow:0 12px 40px #00000026}.marquee-item img{transition:transform .5s}.marquee-item:hover img{transform:scale(1.05)}.marquee-overlay{opacity:0;pointer-events:none;background:linear-gradient(#0000 0%,#0006 40%,#000000d9 100%);border-radius:0 0 12px 12px;flex-direction:column;align-items:flex-start;gap:.35rem;padding:1.5rem 1.25rem;transition:opacity .35s,transform .35s;display:flex;position:absolute;bottom:0;left:0;right:0;transform:translateY(10px)}@media (min-width:640px){.marquee-overlay{border-radius:0 0 14px 14px;padding:2rem 1.5rem}}@media (min-width:1024px){.marquee-overlay{border-radius:0 0 16px 16px}}.marquee-item:hover .marquee-overlay{opacity:1;transform:translateY(0)}.marquee-category{font-family:var(--font-body);color:var(--accent);text-transform:uppercase;letter-spacing:.1em;background:#ff880026;border-radius:4px;padding:.3rem .6rem;font-size:11px;font-weight:600}@media (min-width:640px){.marquee-category{padding:.35rem .75rem;font-size:12px}}.marquee-title{font-family:var(--font-heading);color:#fff;font-size:20px;font-weight:400;line-height:1.2}@media (min-width:640px){.marquee-title{font-size:24px}}@media (min-width:1024px){.marquee-title{font-size:28px}}@media (prefers-reduced-motion:reduce){.marquee-track{animation:none}}.project-lightbox{z-index:9999;touch-action:none;overscroll-behavior:contain;background:#000000f2;justify-content:center;align-items:center;padding:1rem;animation:.3s lightboxFadeIn;display:flex;position:fixed;inset:0}@keyframes lightboxFadeIn{0%{opacity:0}to{opacity:1}}.project-lightbox-content{justify-content:center;align-items:center;width:100%;max-width:1400px;height:100%;max-height:90vh;display:flex;position:relative}.project-lightbox-image{width:100%;max-width:1200px;height:80vh;position:relative}@media (max-width:640px){.project-lightbox-image{height:60vh}}.project-lightbox-close{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;cursor:pointer;z-index:10001;background:#ffffff1a;border:1px solid #ffffff26;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;font-size:32px;font-weight:300;line-height:1;transition:all .3s;display:flex;position:fixed;top:1.5rem;right:1.5rem}.project-lightbox-close:hover{background:var(--accent);border-color:var(--accent);transform:scale(1.1)}@media (max-width:640px){.project-lightbox-close{width:44px;height:44px;font-size:28px;top:1rem;right:1rem}}.project-lightbox-prev,.project-lightbox-next{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fffc;cursor:pointer;z-index:10001;background:#0006;border:1px solid #ffffff1a;border-radius:12px;justify-content:center;align-items:center;width:56px;height:56px;font-size:36px;font-weight:300;line-height:1;transition:all .3s;display:flex;position:fixed;top:50%;transform:translateY(-50%)}.project-lightbox-prev{left:1.5rem}.project-lightbox-next{right:1.5rem}.project-lightbox-prev:hover,.project-lightbox-next:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:translateY(-50%)scale(1.05)}@media (max-width:640px){.project-lightbox-prev,.project-lightbox-next{border-radius:8px;width:44px;height:44px;font-size:28px}.project-lightbox-prev{left:.75rem}.project-lightbox-next{right:.75rem}}.project-lightbox-caption{z-index:10001;text-align:center;flex-direction:column;align-items:center;gap:.5rem;display:flex;position:fixed;bottom:2.5rem;left:50%;transform:translate(-50%)}.project-lightbox-title{font-family:var(--font-heading);color:#fff;font-size:28px;font-weight:400;line-height:1.2}@media (min-width:640px){.project-lightbox-title{font-size:36px}}@media (min-width:1024px){.project-lightbox-title{font-size:42px}}@media (max-width:640px){.project-lightbox-caption{bottom:1.5rem}.project-lightbox-title{font-size:24px}}.project-lightbox-counter{color:#fff9;font-family:var(--font-body);z-index:10001;background:#00000080;border-radius:20px;padding:.5rem 1rem;font-size:14px;position:fixed;top:1.5rem;left:50%;transform:translate(-50%)}@media (max-width:640px){.project-lightbox-counter{padding:.4rem .8rem;font-size:12px;top:1rem}}
.contact-catcher-container{background:var(--background);color:var(--foreground);flex-direction:column;justify-content:center;align-items:center;width:100%;padding:6rem 1.5rem;display:flex;position:relative}@media (min-width:640px){.contact-catcher-container{padding:8rem 3rem}}@media (min-width:1024px){.contact-catcher-container{padding:10rem 6rem}}.contact-catcher-content{flex-direction:column;align-items:flex-start;width:100%;max-width:900px;display:flex}.contact-catcher-headline{font-family:var(--font-body);color:var(--accent);margin:0;padding-bottom:3rem;font-size:18px;font-weight:400;line-height:1.6}@media (min-width:640px){.contact-catcher-headline{padding-bottom:4rem;font-size:20px}}@media (min-width:1024px){.contact-catcher-headline{padding-bottom:5rem;font-size:22px}}.contact-links{flex-direction:column;align-items:flex-start;gap:2rem;display:flex}@media (min-width:640px){.contact-links{gap:2.5rem}}@media (min-width:1024px){.contact-links{gap:3rem}}.contact-link{font-family:var(--font-heading);color:var(--foreground);font-weight:400;text-decoration:none;transition:all .3s;display:block;position:relative}.contact-phone{letter-spacing:.02em;font-size:40px}@media (min-width:640px){.contact-phone{font-size:56px}}@media (min-width:1024px){.contact-phone{font-size:72px}}@media (min-width:1280px){.contact-phone{font-size:80px}}.contact-email{letter-spacing:.01em;font-size:24px}@media (min-width:640px){.contact-email{font-size:32px}}@media (min-width:1024px){.contact-email{font-size:40px}}@media (min-width:1280px){.contact-email{font-size:48px}}.contact-link:hover{color:var(--accent);transform:translate(10px)}@media (min-width:1024px){.contact-link:hover{transform:translate(20px)}}.contact-link:active{transform:scale(.98)}@media (prefers-reduced-motion:reduce){.contact-link{transition:none}.contact-link:hover{transform:none}}.contact-legal-links{display:none}@media (min-width:1024px){.contact-legal-links{display:block;position:absolute;bottom:6rem;right:8rem}.contact-legal-links-inner{flex-direction:column;align-items:center;gap:2rem;display:flex}.contact-legal-link{font-family:var(--font-body);color:#0006;writing-mode:vertical-rl;text-orientation:mixed;letter-spacing:.1em;font-size:14px;text-decoration:none;transition:color .3s}.contact-legal-link:hover{color:var(--accent)}}
