.project-story{display:flex;justify-content:space-between;padding-top:90px}.project-info-text{max-width:720px}.project-story-left{position:-webkit-sticky;position:sticky;top:90px;max-height:calc(100vh - 90px);overflow-y:hidden}.project-story-left p{color:var(--color-text-light)}.project-story-right{padding-left:80px}.project-detail{margin:20px 0}.active-section{font-weight:700}.table-of-contents-wrapper{min-width:280px;margin-right:16px;border-radius:var(--border-radius-large)}.social-icons{display:flex;gap:16px}.social-icons a{opacity:.7;transition:opacity .2s}.social-icons a:hover{opacity:1}@keyframes staggered-hover{0%{opacity:.7}to{opacity:1;transform:rotate(5deg)}}@media (max-width:1024px){.project-story{flex-direction:column}.project-story-left{position:static;margin-bottom:48px}.project-info-text{max-width:100%}.project-story-right{padding-left:0}}.animated-link{display:inline-flex;align-items:center;gap:2px;font-weight:600;text-decoration:none;color:var(--color-primary);padding:4px 0;cursor:pointer;transition:color .3s ease}.link-text{position:relative}.link-text:after{content:"";position:absolute;left:0;bottom:-4px;width:100%;height:2px;background-color:var(--color-primary);opacity:0;transition:transform .3s ease}.animated-link:hover .link-text:after{opacity:1}.arrow-icon{transition:transform .3s ease}.animated-link:hover .arrow-icon{transform:translate(4px,-4px)}.tracker-nav{padding:var(--spacing-xl) 0;background:transparent;z-index:10}.tracker-nav-list{display:flex;gap:var(--spacing-lg);list-style:none;margin:0;padding:0}.tracker-link{color:var(--color-text-light);text-decoration:none;font-size:var(--font-base);padding:var(--spacing-xxs) 0;border-radius:var(--border-radius-small);transition:color .3s ease,background-color .3s ease;position:relative;font-weight:500}.tracker-link-active,.tracker-link:hover{color:var(--color-primary)}.tracker-link-active{font-weight:600}.tracker-link-active:after{content:"";position:absolute;bottom:-2px;left:0;height:2px;width:100%;background-color:var(--color-primary);transform:scaleX(1);border-radius:var(--border-radius-small)}@media (max-width:1024px){.tracker-nav{display:none}}.about-section{padding-bottom:var(--spacing-xxl);color:var(--color-text);font-family:Jost,sans-serif}.about-title{margin-bottom:var(--spacing-xl);opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}.about-content{max-width:600px;display:flex;flex-direction:column}.about-text{font-size:var(--font-md);line-height:1.75;color:var(--color-text-light);opacity:0;transform:translateY(40px);transition:opacity .7s ease,transform .7s ease}.fade-in{opacity:1;transform:translateY(0)}.delay-1{transition-delay:.3s}.delay-2{transition-delay:.5s}.delay-3{transition-delay:.7s}.skills-section{padding:var(--spacing-xxl) 0;background-color:var(--color-background)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));grid-gap:var(--spacing-lg);gap:var(--spacing-lg);max-width:1200px;margin:0 auto}.skills-card{background-color:var(--color-light);border:1px solid var(--color-border);border-radius:var(--border-radius-small);padding:var(--spacing-lg);box-shadow:var(--box-shadow-light);opacity:0;transform:translateY(30px) scale(.98);transition:transform .6s ease,opacity .6s ease}.skills-card.in-view{opacity:1;transform:translateY(0) scale(1)}.skills-card-title{font-size:var(--font-md);font-weight:600;color:var(--color-title);margin:0;border-bottom:1px solid var(--color-gray);padding-bottom:var(--spacing-xs)}.skills-list{list-style:none;padding:0;margin:0}.skills-list-item{font-size:var(--font-base);color:var(--color-text-light);padding:var(--spacing-xs) 0 var(--spacing-xs) var(--spacing-md);position:relative}.skills-list-item:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:6px;height:6px;background-color:var(--color-primary);border-radius:50%}@media (max-width:600px){.skills-title{font-size:var(--font-xl)}.skills-card{padding:var(--spacing-md)}}.text-arrow-button{position:relative;background:none;border:none;color:var(--color-primary);font-size:1rem;cursor:pointer;display:inline-flex;align-items:center;text-decoration:none;transition:color .3s ease;font-weight:600;padding:4px 0;white-space:no-wrap}.text-arrow-button .arrow-icon{opacity:0;transform:translateX(0);transition:opacity .3s ease,transform .3s ease;color:var(--color-primary);pointer-events:none}.text-arrow-button:hover .arrow-icon{opacity:1;transform:translateX(4px)}.text-arrow-button:after{content:"";position:absolute;left:0;bottom:-4px;width:100%;height:2px;background-color:var(--color-primary);opacity:0;transition:transform .3s ease}.text-arrow-button:hover .text-arrow-button:after{opacity:1}.projects-wrapper{padding-top:var(--spacing-xxl)}.cards-container{display:flex;flex-direction:column;gap:var(--spacing-md);justify-content:center;align-items:center;-webkit-user-select:none;-moz-user-select:none;user-select:none}.project-link-card{position:relative;width:100%;height:-moz-fit-content;height:fit-content;overflow:hidden}.card-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.card-tag{color:var(--color-text);background-color:var(--color-white-background);border:1px solid var(--color-border);padding:var(--spacing-xxs) var(--spacing-xs);border-radius:50px;font-size:var(--font-xs);font-weight:600}.card-content{height:100%;width:100%}.card-image-wrapper{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;border-radius:var(--border-radius-small);margin:var(--spacing-md) 0}.card-image{border:1px solid var(--color-border);object-fit:cover}.card-title-container{display:flex;flex-direction:column}.card-title{margin-top:8px;color:var(--color-title);font-size:24px;font-weight:700;color:var(--color-text);z-index:1}.project-link-card:hover .card-icon{transform:translateY(-15px) translateX(10px)}.project-text{color:var(--color-text-light);margin-bottom:var(--spacing-xl);font-size:var(--font-base)}@media (max-width:768px){.card-tags{gap:8px}.card-image{margin-top:24px;margin-bottom:24px}}:root{--animation-duration-overlay:0.3s;--animation-duration-content:0.4s;--animation-delay-content:0.15s;--modal-offset:12px}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(0,0,0,.5);opacity:0;visibility:hidden;transition:opacity var(--animation-duration-overlay) ease-in-out,visibility 0s linear var(--animation-duration-overlay);z-index:9999999998}.modal-overlay.show{opacity:1;visibility:visible;transition-delay:0s}.modal-content{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) translateY(var(--modal-offset));opacity:0;pointer-events:none;transition:transform var(--animation-duration-content) cubic-bezier(.33,1,.68,1) var(--animation-delay-content),opacity var(--animation-duration-content) ease var(--animation-delay-content);z-index:9999999999;background-color:color-mix(in srgb,var(--color-background,var(--color-white-background)) 96%,transparent);backdrop-filter:blur(32px);-webkit-backdrop-filter:blur(32px);border-radius:var(--border-radius-small);box-shadow:var(--shadow-medium,0 4px 20px rgba(0,0,0,.2));padding:var(--spacing-xl)}.modal-content.show{opacity:1;transform:translate(-50%,-50%) translateY(0);pointer-events:auto}.modal-content.hide{opacity:0;transform:translate(-50%,-50%) translateY(var(--modal-offset));pointer-events:none}.close-button{background:transparent;border:none;font-size:16px;height:32px;width:32px;cursor:pointer;border-radius:50px;position:absolute;top:0;right:0;color:var(--color-text);opacity:.5;transition:opacity .2s}.close-button:hover{opacity:1}@media (max-width:768px){.modal-content{padding:var(--spacing-md)}}.catalogue-wrapper{display:flex;justify-content:center;align-items:center;margin:var(--spacing-md) 0}.catalogue-container.mobile-layout{aspect-ratio:9/16;max-width:140px;min-height:auto}.catalogue-container{position:relative;width:100%;max-width:800px;min-height:360px;perspective:1000px;padding-bottom:40px;transition:all .3s ease-in-out}.catalogue-controls{position:absolute;bottom:0;right:var(--spacing-sm);display:flex;gap:var(--spacing-xs);z-index:3}.catalogue-nav-button{background-color:var(--color-transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:none;font-weight:600;color:var(--color-primary-base);font-size:var(--font-base);border-radius:50%;height:32px;width:32px;cursor:pointer;box-shadow:var(--box-shadow-medium);border:1px solid var(--color-border);transition:background-color .3s ease,transform .2s ease,opacity .2s ease-in-out;opacity:.6}.catalogue-nav-button:hover{opacity:1;transform:scale(1.1)}.nav-prev{left:var(--spacing-sm)}.nav-next{right:var(--spacing-sm)}.catalogue-card-stack{position:absolute;left:0;right:0;margin:auto;width:100%;border-radius:var(--border-radius-small);overflow:hidden;transition:transform .6s ease,opacity .4s ease;background-color:var(--color-background);filter:blur(1px);opacity:.8}.card-active{filter:blur(0);opacity:1}.catalogue-card-image{width:100%;display:block;border-radius:var(--border-radius-small);pointer-events:none;box-shadow:var(--box-shadow-medium);border:1px solid var(--color-border)}.tabs-container{margin:0 auto;font-family:inherit}.tabs-header{display:flex;position:relative;border-bottom:2px solid var(--color-border);margin-bottom:var(--spacing-lg);overflow-x:auto}.tab-button{flex:1 1;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-base);background:none;border:none;cursor:pointer;color:var(--color-text-light);font-weight:600;transition:color .3s ease;position:relative;white-space:nowrap}.tab-button:hover{color:var(--color-primary-alt)}.tab-button.active{color:var(--color-primary)}.tab-indicator{position:absolute;bottom:0;height:2px;background-color:var(--color-primary);transition:all .3s ease;border-radius:2px}.tabs-content-wrapper{background-color:var(--color-light);padding:var(--spacing-md);box-shadow:var(--box-shadow-light);transition:background-color .3s ease;min-height:120px}.tab-content{font-size:var(--font-base);color:var(--color-text)}.fade-in{animation:fadeInSlide .3s ease forwards}@keyframes fadeInSlide{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.case-study-dashboard{display:flex;flex-direction:row;gap:2rem;max-height:calc(100vh - 180px);overflow-y:auto;padding-right:10px;width:800px}.case-study-sidebar{flex:0 0 180px;position:relative}.case-study-content{flex:1 1;overflow-y:auto;padding-bottom:2rem;padding-right:var(--spacing-xs);position:relative;-ms-overflow-style:none;scrollbar-width:none}.case-study-content::-webkit-scrollbar{display:none}.case-study-image{max-width:100%;margin:1rem 0;border-radius:8px}.case-nav-desktop{display:flex;flex-direction:column;gap:10px;position:-webkit-sticky;position:sticky;top:0}.sidebar-mobile{display:none}.case-nav-popup{position:absolute;top:100%;left:0;background:var(--color-background);border-radius:var(--border-radius-large);padding:var(--spacing-xs);z-index:9999;animation:fadeSlideIn .3s ease forwards;width:max-content;min-width:150px;border:1px solid var(--color-border)}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.case-study-content ul{margin-left:1.25rem;margin-bottom:1.5rem;list-style:disc;color:var(--color-title)}.case-nav-popup ul button,.label-button{transition:.2s ease;font-size:var(--font-base);color:var(--color-text-light);width:100%;padding:8px;border-radius:var(--border-radius-small);font-size:var(--font-sm)}.case-nav-popup ul button:hover,.label-button:hover{color:var(--color-title);background-color:var(--color-gray)}.case-nav-desktop ul button:hover{color:var(--color-primary)}.case-study-content strong{color:var(--color-title);font-weight:600}.case-nav-desktop ul,.case-nav-popup ul{list-style:none}@media (max-width:1024px){.case-study-dashboard{width:640px}}@media (max-width:900px){.case-study-dashboard{width:576px}}@media (max-width:768px){.case-study-dashboard{flex-direction:column;width:calc(100vw - 60px);max-height:calc(100vh - 144px)}.case-nav-desktop{display:none}.sidebar-mobile{display:block}.case-study-sidebar{flex:0 0 auto}.menu-toggle{margin:0}.case-study-content,.case-study-dashboard{padding-right:0}}.loading-overlay{position:fixed;inset:0;background-color:var(--color-white-background);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;transition:opacity .4s ease}.spinner{width:50px;height:50px;border-top:6px solid var(--color-primary-tint-2);border:6px solid var(--color-primary-tint-2);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:var(--spacing-md)}.loading-text{font-size:var(--font-base);color:var(--color-primary);font-weight:600;animation:pulse 1.5s ease-in-out infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.contact-banner{background:linear-gradient(135deg,var(--color-primary-tint-1),var(--color-primary-tint-6));padding:var(--spacing-xxl) var(--spacing-xl);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-medium);margin:var(--spacing-xxl) auto;max-width:960px;overflow:hidden}.contact-banner-content{display:flex;flex-direction:column;gap:var(--spacing-md)}.contact-banner-title{font-size:var(--font-xl);font-weight:700;margin:0}.contact-banner-subtitle{font-size:var(--font-md);max-width:600px;line-height:1.6}.contact-banner-btn{margin-top:var(--spacing-sm);background-color:var(--color-white);color:var(--color-primary-base);padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-base);font-weight:600;border-radius:999px;text-decoration:none;transition:background .3s ease,color .3s ease,box-shadow .3s ease;box-shadow:var(--box-shadow-light);width:-moz-fit-content;width:fit-content}.contact-banner-btn:hover{color:var(--color-white);background-color:var(--color-primary-base);box-shadow:var(--box-shadow-hover)}.contact-banner-subtitle,.contact-banner-title{color:var(--color-black)}.footer{text-align:left;padding:var(--spacing-md) 0;color:var(--color-text-light)}.fade-in-footer{opacity:0;transform:translateY(20px);animation:fadeInUp .8s ease-out forwards;animation-delay:.2s}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}footer div p{font-size:var(--font-sm)}.timeline-wrapper{position:relative;padding:var(--spacing-xxl) 0;max-width:900px;margin:auto;background:transparent}.timeline-line{position:absolute;left:6px;top:0;bottom:0;width:4px;background:var(--color-primary)}.timeline-items{display:flex;flex-direction:column;gap:var(--spacing-xl);position:relative;margin-left:40px}.timeline-item{position:relative;display:flex;align-items:flex-start;opacity:1;transform:none}.timeline-marker{position:absolute;left:-38px;width:12px;height:12px;background:var(--color-primary-tint-8);border-radius:50%;border:4px solid var(--color-white);box-shadow:0 0 0 2px var(--color-primary-tint-3);z-index:2}.timeline-card{background:var(--color-white-background);padding:var(--spacing-lg);border-radius:var(--border-radius-small);box-shadow:var(--box-shadow-medium);border:1px solid transparent;transition:transform .3s ease;cursor:pointer}.timeline-card:hover{border:1px solid var(--color-border);box-shadow:var(--box-shadow-hover)}.timeline-card:hover .timeline-title{color:var(--color-primary);text-decoration:underline}.timeline-year{font-weight:600;color:var(--color-primary);font-size:var(--font-sm)}.timeline-title{margin:var(--spacing-xs) 0;font-size:var(--font-md);font-weight:700;color:var(--color-title)}.timeline-desc{margin:0;padding-bottom:var(--spacing-sm);color:var(--color-text-light);font-size:var(--font-sm);line-height:1.6}@media (max-width:768px){.timeline-items{margin-left:24px}.timeline-marker{left:-22px}}.tags-container{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:var(--spcaing-md) 0}.tag-item{padding:.2rem .7rem;font-size:var(--font-xs);font-weight:500;color:var(--color-text);background-color:var(--color-background);border:1px solid var(--color-border);border-radius:9999px;white-space:nowrap}.how-i-may-help-section{width:100%;padding:var(--spacing-xlg) var(--spacing-sm);background-color:var(--color-white-background);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-medium)}.how-i-may-help-section h2{font-size:var(--font-xl);font-weight:700;color:var(--color-title);margin-bottom:var(--spacing-md);text-align:center}.how-i-may-help-section p.section-intro{font-size:var(--font-base);color:var(--color-text-light);max-width:40rem;margin:0 auto var(--spacing-xl);text-align:center}.service-grid{display:grid;grid-gap:var(--spacing-md);gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.service-card{background-color:var(--color-background);padding:var(--spacing-lg);border-radius:var(--border-radius-large);border:1px solid var(--color-border);transition:box-shadow .3s ease;box-shadow:var(--box-shadow-light)}.service-card:hover{box-shadow:var(--box-shadow-hover)}.service-icon{margin-bottom:var(--spacing-sm)}.service-title{font-size:var(--font-md);font-weight:600;color:var(--color-title);margin-bottom:var(--spacing-xs)}.service-description{font-size:var(--font-sm);color:var(--color-text-light)}.how-i-may-help-cta{display:inline-flex;align-items:center;gap:var(--spacing-xs);background-color:var(--color-primary);color:var(--color-white);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--border-radius-large);margin-top:var(--spacing-xl);text-decoration:none;transition:background-color .3s ease}.how-i-may-help-cta:hover{background-color:var(--color-primary-active)}.pre-fade{opacity:0;transform:scale(.95) translateY(30px);filter:blur(4px);transition:opacity .7s ease,transform .7s ease,filter .7s ease}.fade-in-up{opacity:1;transform:scale(1) translateY(0);filter:blur(0)}.how-help-card{transition-delay:var(--stagger-delay)}