:root{--red:#e04e3e;--red-dark:#c73b32;--red-darker:#b8342c;--red-light:#e86052;--red-lightest:#fdf0ef;--black:#1a1a1a;--gray-900:#2d2d2d;--gray-700:#555;--gray-500:#888;--gray-300:#ccc;--gray-100:#f5f5f5;--white:#fff;--font-heading:"Space Grotesk", sans-serif;--font-body:"Inter", sans-serif;--header-height:72px;--section-padding:clamp(60px, 10vw, 120px);--container-width:1200px;--container-padding:clamp(20px, 4vw, 40px);--transition-fast:.2s cubic-bezier(.4, 0, .2, 1);--transition-medium:.4s cubic-bezier(.4, 0, .2, 1);--transition-slow:.6s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);color:var(--black);background:var(--white);line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;line-height:1.2}h1{font-size:clamp(2.5rem,6vw,4.5rem)}h2{font-size:clamp(2rem,4vw,3rem)}h3{font-size:clamp(1.25rem,2.5vw,1.75rem)}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;background:0 0;border:none;font-family:inherit}.container{max-width:var(--container-width);padding:0 var(--container-padding);margin:0 auto}.page-enter{opacity:0;transform:translateY(20px)}.page-enter-active{opacity:1;transition:opacity var(--transition-medium), transform var(--transition-medium);transform:translateY(0)}.reveal{opacity:0;transition:opacity var(--transition-slow), transform var(--transition-slow);transform:translateY(30px)}.reveal.visible{opacity:1;transform:translateY(0)}::selection{background:var(--red);color:var(--white)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--gray-100)}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--red)}.section{padding:var(--section-padding) 0}.section-label{font-family:var(--font-heading);text-transform:uppercase;letter-spacing:.15em;color:var(--red);align-items:center;gap:.75rem;margin-bottom:1.5rem;font-size:.75rem;font-weight:600;display:flex}.section-label:before{content:"";background:var(--red);width:24px;height:2px;display:block}.btn{font-family:var(--font-heading);letter-spacing:.05em;transition:all var(--transition-fast);border-radius:4px;align-items:center;gap:.5rem;padding:.875rem 1.75rem;font-size:.875rem;font-weight:600;display:inline-flex}.btn-primary{background:var(--red);color:var(--white)}.btn-primary:hover{background:var(--red-dark);transform:translateY(-2px);box-shadow:0 4px 20px #e04e3e4d}.btn-outline{border:2px solid var(--black);color:var(--black)}.btn-outline:hover{background:var(--black);color:var(--white);transform:translateY(-2px)}.btn-ghost{color:var(--red);border-bottom:2px solid #0000;padding:.5rem 0}.btn-ghost:hover{border-bottom-color:var(--red)}.btn-arrow:after{content:"→";transition:transform var(--transition-fast)}.btn-arrow:hover:after{transform:translate(4px)}.site-header{z-index:1000;height:var(--header-height);transition:background var(--transition-fast), box-shadow var(--transition-fast);position:fixed;top:0;left:0;right:0}.site-header.scrolled{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--gray-100);background:#fffffff2}.header-inner{justify-content:space-between;align-items:center;height:100%;display:flex}.logo{transition:transform var(--transition-fast);align-items:center;display:flex}.logo:hover{transform:scale(1.05)}.nav{align-items:center;gap:2rem;display:flex}.nav-link{font-family:var(--font-heading);letter-spacing:.02em;color:var(--gray-700);transition:color var(--transition-fast);font-size:.875rem;font-weight:500;position:relative}.nav-link:after{content:"";background:var(--red);width:0;height:2px;transition:width var(--transition-fast);position:absolute;bottom:-4px;left:0}.nav-link:hover,.nav-link.active{color:var(--black)}.nav-link.active:after,.nav-link:hover:after{width:100%}.nav-cta{padding:.625rem 1.25rem;font-size:.8125rem}.menu-toggle{z-index:1001;flex-direction:column;gap:5px;padding:8px;display:none}.menu-toggle span{background:var(--black);width:24px;height:2px;transition:all var(--transition-fast);transform-origin:50%;display:block}.menu-toggle.open span:first-child{transform:translateY(7px)rotate(45deg)}.menu-toggle.open span:nth-child(2){opacity:0}.menu-toggle.open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}@media (width<=768px){.menu-toggle{display:flex}.nav{background:var(--white);width:280px;transition:transform var(--transition-medium);flex-direction:column;align-items:flex-start;gap:1.5rem;padding:100px 40px 40px;position:fixed;top:0;bottom:0;right:0;transform:translate(100%);box-shadow:-4px 0 30px #0000001a}.nav.open{transform:translate(0)}.nav-link{font-size:1.125rem}.nav-cta{margin-top:1rem}}.site-footer{border-top:1px solid var(--gray-100);margin-top:auto;padding:3rem 0}.footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.5rem;display:flex}.footer-copyright{color:var(--gray-700);font-size:.875rem}.footer-location{color:var(--gray-500);margin-top:.25rem;font-size:.75rem}.footer-nav{gap:1.5rem;display:flex}.footer-nav a{font-family:var(--font-heading);color:var(--gray-700);transition:color var(--transition-fast);font-size:.8125rem;font-weight:500}.footer-nav a:hover{color:var(--red)}.footer-social{gap:1.25rem;display:flex}.footer-social a{color:var(--gray-500);transition:color var(--transition-fast);font-size:.8125rem;font-weight:500}.footer-social a:hover{color:var(--red)}@media (width<=768px){.footer-inner{text-align:center;flex-direction:column}}.carousel{margin-top:2rem}.carousel-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.carousel-counter{font-family:var(--font-heading);color:var(--gray-500);align-items:center;gap:.25rem;font-size:.875rem;display:flex}.carousel-current{color:var(--black);font-weight:600}.carousel-controls{gap:.5rem;display:flex}.carousel-btn{border:2px solid var(--gray-300);width:44px;height:44px;color:var(--black);transition:all var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;font-size:1.125rem;display:flex}.carousel-btn:hover:not(:disabled){border-color:var(--red);color:var(--red)}.carousel-btn:disabled{opacity:.3;cursor:not-allowed}.carousel-track{scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:1.5rem;padding-bottom:1rem;display:flex;overflow-x:auto}.carousel-track::-webkit-scrollbar{display:none}.project-card{scroll-snap-align:start;border:1px solid var(--gray-100);transition:all var(--transition-medium);border-radius:12px;flex:0 0 340px;display:block;overflow:hidden}.project-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #00000014}.card-top{justify-content:center;align-items:center;height:180px;display:flex;position:relative;overflow:hidden}.card-logo{object-fit:contain;filter:brightness(0)invert();max-width:70%;max-height:80px;transition:transform var(--transition-fast)}.project-card:hover .card-logo{transform:scale(1.05)}.card-logo.card-logo-cover{object-fit:cover;filter:none;width:100%;max-width:100%;height:100%;max-height:100%}.card-logo.card-logo-original{filter:none}.card-abbr{font-family:var(--font-heading);color:#ffffffe6;letter-spacing:.05em;font-size:3rem;font-weight:700}.card-body{padding:1.5rem}.card-title{margin-bottom:.25rem;font-size:1.125rem;font-weight:600}.card-subtitle{color:var(--gray-500);margin-bottom:1rem;font-size:.875rem}.card-tags{flex-wrap:wrap;gap:.5rem;display:flex}.card-tag{background:var(--gray-100);color:var(--gray-700);border-radius:100px;padding:.25rem .625rem;font-size:.6875rem;font-weight:500}@media (width<=768px){.project-card{flex:0 0 280px}.card-top{height:140px}}.hero{padding-top:calc(var(--header-height) + var(--section-padding));align-items:center;min-height:85vh;display:flex}.hero-greeting{font-family:var(--font-heading);color:var(--red);margin-bottom:1rem;font-size:clamp(1.25rem,2.5vw,1.5rem);font-weight:600}.hero-title{max-width:800px;margin-bottom:1.5rem}.hero-name{color:var(--red)}.hero-sub{color:var(--gray-700);max-width:600px;margin-bottom:2.5rem;font-size:clamp(1rem,1.5vw,1.125rem);line-height:1.7}.hero-actions{flex-wrap:wrap;gap:1rem;display:flex}.work-section .section-desc{color:var(--gray-700);max-width:500px;margin-top:.75rem;font-size:.9375rem}.work-more{margin-top:2rem}.services-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:2.5rem;display:grid}.service-item{border:1px solid var(--gray-100);transition:all var(--transition-medium);border-radius:12px;padding:2rem}.service-item:hover{border-color:var(--red-lightest);background:var(--red-lightest)}.service-icon{background:var(--red-lightest);width:48px;height:48px;color:var(--red);border-radius:10px;justify-content:center;align-items:center;margin-bottom:1rem;font-size:1.5rem;font-weight:600;display:flex}.service-item h3{margin-bottom:.5rem}.service-item p{color:var(--gray-700);font-size:.875rem;line-height:1.6}.cta-section{padding-bottom:var(--section-padding)}.cta-box{background:var(--black);color:var(--white);text-align:center;border-radius:16px;padding:clamp(2.5rem,6vw,4rem)}.cta-box h2{color:var(--white);margin-bottom:1rem}.cta-box p{color:var(--gray-300);max-width:500px;margin:0 auto 2rem;font-size:.9375rem}@media (width<=768px){.hero{min-height:auto;padding-top:calc(var(--header-height) + 60px);padding-bottom:60px}.services-grid{grid-template-columns:1fr}}.work-page .page-hero{padding-top:calc(var(--header-height) + var(--section-padding));padding-bottom:0}.page-hero-sub{color:var(--gray-700);max-width:600px;margin-top:1rem;font-size:1.0625rem;line-height:1.7}.work-grid{gap:2rem;display:grid}.work-card{border:1px solid var(--gray-100);transition:all var(--transition-medium);border-radius:12px;grid-template-columns:300px 1fr;display:grid;overflow:hidden}.work-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #00000014}.work-card-visual{justify-content:center;align-items:center;min-height:200px;display:flex}.work-card-logo{object-fit:contain;filter:brightness(0)invert();max-width:70%;max-height:80px;transition:transform var(--transition-fast)}.work-card:hover .work-card-logo{transform:scale(1.05)}.work-card-logo.work-card-logo-cover{object-fit:cover;filter:none;width:100%;max-width:100%;height:100%;max-height:100%}.work-card-logo.work-card-logo-original{filter:none}.work-card-abbr{font-family:var(--font-heading);color:#ffffffe6;letter-spacing:.05em;font-size:3rem;font-weight:700}.work-card-info{flex-direction:column;padding:2rem;display:flex}.work-card-header{margin-bottom:.75rem}.work-card-header h3{margin-bottom:.25rem}.work-card-role{color:var(--red);font-size:.8125rem;font-weight:500}.work-card-desc{color:var(--gray-700);flex:1;margin-bottom:1rem;font-size:.875rem;line-height:1.65}.work-card-tags{flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;display:flex}.work-card-link{font-family:var(--font-heading);color:var(--red);transition:gap var(--transition-fast);font-size:.8125rem;font-weight:600}@media (width<=768px){.work-card{grid-template-columns:1fr}.work-card-visual{min-height:140px}}.tech-badge{background:var(--white);border:1px solid var(--gray-100);transition:all var(--transition-fast);border-radius:100px;align-items:center;gap:.5rem;padding:.5rem 1rem;display:inline-flex}.tech-badge:hover{border-color:var(--red);background:var(--red-lightest)}.tech-badge-icon{object-fit:contain;width:20px;height:20px}.tech-badge-label{font-family:var(--font-heading);color:var(--gray-700);font-size:.8125rem;font-weight:500}.tech-badge-dot{background:var(--red);border-radius:50%;width:8px;height:8px}.tech-badge-lg{padding:.625rem 1.25rem}.tech-badge-lg .tech-badge-icon{width:24px;height:24px}.tech-badge-lg .tech-badge-label{font-size:.875rem}.services-page .page-hero{padding-top:calc(var(--header-height) + var(--section-padding));padding-bottom:0}.svc-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.svc-card{border:1px solid var(--gray-100);cursor:pointer;transition:all var(--transition-medium);background:var(--white);border-radius:16px;position:relative;overflow:hidden}.svc-card:hover{border-color:var(--red);transform:translateY(-4px);box-shadow:0 8px 32px #e04e3e14}.svc-card.active{border-color:var(--red);background:var(--black);color:var(--white);transform:translateY(-4px);box-shadow:0 16px 48px #00000026}.svc-card-front{min-height:280px;transition:opacity var(--transition-medium);flex-direction:column;padding:2rem;display:flex}.svc-card.active .svc-card-front{opacity:0;pointer-events:none;position:absolute}.svc-card-number{font-family:var(--font-heading);color:var(--red);letter-spacing:.1em;margin-bottom:1.5rem;font-size:.6875rem;font-weight:600}.svc-card-icon{background:var(--red-lightest);width:56px;height:56px;color:var(--red);transition:all var(--transition-fast);border-radius:14px;justify-content:center;align-items:center;margin-bottom:1.25rem;font-size:2rem;font-weight:600;display:flex}.svc-card:hover .svc-card-icon{background:var(--red);color:var(--white)}.svc-card-front h3{margin-bottom:.5rem;font-size:1.25rem}.svc-card-front p{color:var(--gray-500);flex:1;font-size:.875rem;line-height:1.65}.svc-card:hover .svc-card-front p{color:var(--gray-700)}.svc-card-expand{font-family:var(--font-heading);color:var(--red);transition:gap var(--transition-fast);margin-top:1rem;font-size:.75rem;font-weight:600}.svc-card-detail{flex-direction:column;min-height:280px;padding:2rem;display:none}.svc-card.active .svc-card-detail{display:flex}.svc-card-detail-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.svc-card-detail-header h4{color:var(--white);font-size:1.125rem}.svc-card-close{color:var(--gray-500);transition:color var(--transition-fast);font-size:1.5rem;line-height:1}.svc-card-close:hover{color:var(--white)}.svc-card-detail p{color:var(--gray-500);margin-bottom:1.25rem;font-size:.8125rem;line-height:1.6}.svc-card-techs{flex-wrap:wrap;gap:.5rem;display:flex}.svc-card.active .tech-badge{background:#ffffff14;border-color:#ffffff26}.svc-card.active .tech-badge-label{color:var(--gray-300)}.svc-card.active .tech-badge:hover{border-color:var(--red);background:#ffffff26}.process-section{background:var(--gray-100);margin:0 calc(-1 * var(--container-padding));padding-left:var(--container-padding);padding-right:var(--container-padding);border-radius:0}.process-grid{grid-template-columns:repeat(4,1fr);gap:0;margin-top:3rem;display:grid;position:relative}.process-step{text-align:center;flex-direction:column;align-items:center;display:flex;position:relative}.process-step-line{justify-content:center;align-items:center;width:100%;height:40px;margin-bottom:1.5rem;display:flex;position:relative}.process-dot{background:var(--red);z-index:2;width:16px;height:16px;box-shadow:0 0 0 4px var(--red-lightest);border-radius:50%;position:relative}.process-connector{background:var(--gray-300);height:2px;position:absolute;top:50%;left:calc(50% + 12px);right:calc(12px - 50%);transform:translateY(-50%)}.process-step-content{padding:0 1rem}.process-step-num{font-family:var(--font-heading);color:var(--red);letter-spacing:.1em;margin-bottom:.5rem;font-size:.6875rem;font-weight:700;display:block}.process-step-content h3{margin-bottom:.5rem;font-size:1.125rem}.process-step-content p{color:var(--gray-700);font-size:.8125rem;line-height:1.6}.svc-cta{background:var(--black);border-radius:20px;grid-template-columns:1.2fr .8fr;align-items:center;gap:3rem;padding:clamp(2.5rem,5vw,4rem);display:grid}.svc-cta h2{color:var(--white);margin-bottom:1rem}.svc-cta-content p{color:var(--gray-500);margin-bottom:2rem;font-size:.9375rem;line-height:1.7}.svc-cta-actions{flex-wrap:wrap;gap:1rem;display:flex}.svc-cta-actions .btn-ghost{color:var(--gray-300);border-bottom-color:#0000}.svc-cta-actions .btn-ghost:hover{color:var(--white);border-bottom-color:var(--white)}.svc-cta-stats{border-left:1px solid #ffffff1a;flex-direction:column;gap:1.5rem;padding-left:3rem;display:flex}.stat{flex-direction:column;gap:.25rem;display:flex}.stat-num{font-family:var(--font-heading);color:var(--red);font-size:2rem;font-weight:700;line-height:1}.stat-label{color:var(--gray-500);font-size:.8125rem}@media (width<=1024px){.svc-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.svc-grid{grid-template-columns:1fr}.svc-card-front,.svc-card-detail{min-height:auto;padding:1.5rem}.process-grid{grid-template-columns:1fr;gap:2rem}.process-step{text-align:left;flex-direction:row;align-items:flex-start}.process-step-line{flex-direction:column;flex-shrink:0;width:40px;height:auto;margin-bottom:0;margin-right:1rem}.process-connector{width:2px;height:auto;position:absolute;inset:calc(50% + 12px) auto calc(-100% - 12px) 50%;transform:translate(-50%)}.process-step-content{padding:0}.svc-cta{text-align:center;grid-template-columns:1fr}.svc-cta-actions{justify-content:center}.svc-cta-stats{border-top:1px solid #ffffff1a;border-left:none;flex-direction:row;justify-content:center;padding-top:1.5rem;padding-left:0}.stat{align-items:center}}.about-page .page-hero{padding-top:calc(var(--header-height) + var(--section-padding));padding-bottom:0}.bio-grid{grid-template-columns:240px 1fr;align-items:start;gap:3rem;display:grid}.bio-avatar{position:relative}.avatar-img{object-fit:cover;filter:grayscale(0);width:240px;height:240px;transition:filter var(--transition-medium);border-radius:16px}.avatar-img:hover{filter:grayscale(.3)}.bio-lead{color:var(--black);margin-bottom:1.25rem;font-size:1.125rem;font-weight:500;line-height:1.7}.bio-text p{color:var(--gray-700);margin-bottom:1rem;font-size:.9375rem;line-height:1.75}.clients-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-top:1.5rem;display:grid}.client-card{border:1px solid var(--gray-100);text-align:center;font-family:var(--font-heading);color:var(--gray-700);transition:all var(--transition-fast);border-radius:8px;padding:1.25rem;font-size:.9375rem;font-weight:600}.client-card:hover{border-color:var(--red);color:var(--red);background:var(--red-lightest)}.timeline{margin-top:2rem}.timeline-item{border-bottom:1px solid var(--gray-100);grid-template-columns:200px 1fr;gap:2rem;padding:2rem 0;display:grid}.timeline-item:first-child{border-top:1px solid var(--gray-100)}.timeline-period{font-family:var(--font-heading);color:var(--gray-500);padding-top:.25rem;font-size:.8125rem;font-weight:500}.timeline-content h3{margin-bottom:.5rem;font-size:1.125rem}.timeline-company{color:var(--red);font-weight:500}.timeline-content p{color:var(--gray-700);font-size:.875rem;line-height:1.65}.tech-grid{flex-wrap:wrap;gap:.75rem;margin-top:1.5rem;display:flex}.about-page .cta-box{background:var(--black);color:var(--white);text-align:center;border-radius:16px;padding:clamp(2.5rem,6vw,4rem)}.about-page .cta-box h2{color:var(--white);margin-bottom:1rem}.about-page .cta-box p{color:var(--gray-300);max-width:500px;margin:0 auto 2rem;font-size:.9375rem}@media (width<=768px){.bio-grid{text-align:center;grid-template-columns:1fr}.avatar-img{width:180px;height:180px;margin:0 auto}.timeline-item{grid-template-columns:1fr;gap:.5rem}.clients-grid{grid-template-columns:repeat(2,1fr)}}.contact-page .page-hero{padding-top:calc(var(--header-height) + var(--section-padding));padding-bottom:0}.contact-grid{grid-template-columns:1fr 1fr;align-items:start;gap:3rem;display:grid}.contact-methods{flex-direction:column;gap:1.5rem;display:flex}.contact-card{border:1px solid var(--gray-100);transition:all var(--transition-fast);border-radius:12px;padding:2rem}.contact-card:hover{border-color:var(--red-lightest);background:var(--red-lightest)}.contact-icon{background:var(--red-lightest);width:40px;height:40px;color:var(--red);font-family:var(--font-heading);border-radius:8px;justify-content:center;align-items:center;margin-bottom:1rem;font-size:.875rem;font-weight:700;display:inline-flex}.contact-card h3{margin-bottom:.5rem;font-size:1rem}.contact-value{color:var(--red);transition:opacity var(--transition-fast);margin-bottom:.5rem;font-size:.9375rem;font-weight:500;display:inline-block}.contact-value:hover{opacity:.8}.contact-note{color:var(--gray-500);font-size:.8125rem}.contact-cta-box{background:var(--black);color:var(--white);top:calc(var(--header-height) + 2rem);border-radius:16px;padding:clamp(2rem,4vw,3rem);position:sticky}.contact-cta-box h2{color:var(--white);margin-bottom:1rem}.contact-cta-box p{color:var(--gray-300);margin-bottom:2rem;font-size:.9375rem;line-height:1.7}.contact-cta-actions{flex-direction:column;gap:.75rem;display:flex}.contact-cta-actions .btn-outline{border-color:var(--gray-500);color:var(--white)}.contact-cta-actions .btn-outline:hover{background:var(--white);color:var(--black);border-color:var(--white)}@media (width<=768px){.contact-grid{grid-template-columns:1fr}.contact-cta-box{position:static}}
