:root{--color-bg: #fefefe;--color-bg-light: #f8f8f8;--color-text: #1a1a1a;--color-text-light: #666;--color-border: #e8e8e8;--color-accent: #d0d0d0;--color-primary: #2a2a2a;--color-secondary: #5a5a5a;--font-serif: "Merriweather", Georgia, serif;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--container-width: 1200px;--content-width: 800px;--spacing-unit: 1rem;--transition-base: .2s ease;--transition-smooth: .3s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .5s cubic-bezier(.68, -.55, .265, 1.55);--shadow-subtle: 0 2px 8px rgba(0, 0, 0, .04);--shadow-medium: 0 4px 12px rgba(0, 0, 0, .06);--shadow-elevated: 0 8px 24px rgba(0, 0, 0, .08);--radius-sm: 2px;--radius-md: 4px;--radius-lg: 8px;--color-primary: #2563eb;--color-primary-light: #dbeafe;--color-surface: #ffffff;--color-elevated: #f8fafc;--color-primary: #1a1a1a;--color-secondary: #4a4a4a;--font-weight-heading: 700;--font-weight-subheading: 500}*,*:before,*:after{box-sizing:border-box;margin:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-sans);font-weight:300;line-height:1.6;color:var(--color-text);background-color:var(--color-bg);min-height:100vh;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}h1,h2,h3,h4{font-family:var(--font-serif);font-weight:700;line-height:1.2;margin-bottom:1.5rem;letter-spacing:-.01em}h1{font-size:3.5rem;letter-spacing:-.02em;background:linear-gradient(to right,var(--color-text),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}h2{font-size:2.25rem;position:relative;display:inline-block}h2:after{content:"";position:absolute;bottom:-8px;left:0;width:60px;height:2px;background-color:var(--color-border);transition:width .3s ease}h2:hover:after{width:100px}h3{font-size:1.5rem}p{margin-bottom:1.5rem}h1,h2,h3,h4{font-family:var(--font-serif);font-weight:700;letter-spacing:-.01em}.lead{font-size:1.15rem;line-height:1.7;color:var(--color-secondary)}a{color:inherit;text-decoration:none;transition:color .2s ease}a:hover{color:var(--color-secondary)}.hero{background:linear-gradient(135deg,var(--color-elevated) 0%,var(--color-bg) 100%);border-bottom:1px solid var(--color-border)}.hero-title{font-weight:var(--font-weight-heading);letter-spacing:-.02em}.tech-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem;margin-top:1.5rem}.tech-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem;text-align:center;transition:all .2s ease}.tech-item:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-subtle)}.container{width:100%;max-width:var(--container-width);margin:0 auto;padding:0 1.5rem}.content-width{width:100%;max-width:var(--content-width);margin:0 auto}.text-center{text-align:center}.fade-in{opacity:0;transform:translateY(20px);transition:opacity .6s var(--transition-smooth),transform .6s var(--transition-smooth)}.fade-in-visible{opacity:1;transform:translateY(0)}::view-transition-old(root),::view-transition-new(root){animation-duration:.4s}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.fade-in{opacity:1;transform:none;transition:none}}:focus-visible{outline:2px solid var(--color-primary);outline-offset:4px;border-radius:var(--radius-sm)}::selection{background-color:#0000001a;color:var(--color-text)}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--color-bg-light)}::-webkit-scrollbar-thumb{background:var(--color-accent);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--color-secondary)}@media(max-width:768px){h1{font-size:2.5rem}h2{font-size:1.75rem}h3{font-size:1.25rem}.container{padding:0 1rem}}.scroll-progress{position:fixed;top:0;left:0;width:0%;height:3px;background:var(--color-primary);z-index:1001;transition:width .1s ease}.section-nav{position:fixed;top:50%;right:2rem;transform:translateY(-50%);z-index:1000}.section-nav ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1.5rem}.nav-dot{display:block;width:12px;height:12px;border-radius:50%;background:var(--color-border);position:relative;transition:all .3s ease}.nav-dot.active{background:var(--color-primary);transform:scale(1.2)}.nav-dot:hover{transform:scale(1.3);background:var(--color-text)}.nav-dot span{position:absolute;right:25px;top:50%;transform:translateY(-50%);white-space:nowrap;font-size:.875rem;opacity:0;transition:opacity .3s ease;color:var(--color-text)}.nav-dot:hover span{opacity:1}.container{max-width:1200px;margin:0 auto;width:100%}.section-header{margin-bottom:4rem}.section-title{font-size:2.5rem;margin-bottom:.5rem;display:flex;align-items:baseline;gap:1rem}.title-number{font-size:1rem;font-weight:400;color:var(--color-text-light);opacity:.5}.section-subtitle{font-size:1.125rem;color:var(--color-text-light);font-weight:300}.is-visible{opacity:1!important;transform:translateY(0)!important}@media(max-width:768px){.section-nav{right:1rem}.nav-dot span{display:none}}.about-card,.project-card,.service-item,.contact-method{will-change:transform,opacity;backface-visibility:hidden}.project-card{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}.project-card.animated{opacity:1;transform:translateY(0)}@media(min-width:768px){h1,h2,h3,h4{font-family:Merriweather,Georgia,serif}}.section{min-height:100vh;padding:6rem 1.5rem;display:flex;flex-direction:column;justify-content:center;position:relative}.section:not(:last-child){border-bottom:1px solid var(--color-border)}.hero-section{background:linear-gradient(135deg,#fefefe,#f8f8f8);text-align:center;display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1rem}.hero-content{width:100%;max-width:800px;margin:0 auto;padding:0 1.5rem}.hero-title{font-size:clamp(3rem,8vw,4rem);font-weight:700;margin:0 0 .5rem;line-height:1.1;letter-spacing:-.02em;color:var(--color-text);position:relative;display:inline-block;padding-bottom:12px;text-shadow:0 2px 4px rgba(0,0,0,.05)}.hero-title:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--color-primary) 0%,rgba(26,26,26,.8) 25%,rgba(26,26,26,.4) 50%,rgba(26,26,26,.1) 75%,rgba(26,26,26,0) 100%);border-radius:2px;opacity:.6;transition:opacity .3s ease}.hero-title:hover:after{opacity:.8}.hero-q{font-size:1.15em;font-weight:600;color:var(--color-primary);font-family:Inter,Arial,sans-serif;letter-spacing:-.03em;position:relative;top:0;text-shadow:0 2px 8px rgba(26,26,26,.1)}.hero-q:after{display:none}.hero-subtitle{font-size:clamp(1rem,3vw,1.25rem);font-weight:400;color:var(--color-text-light);letter-spacing:.08em;text-transform:uppercase;margin:.75rem 0 2rem;font-family:var(--font-sans);position:relative}.hero-subtitle:before,.hero-subtitle:after{content:"";position:absolute;top:50%;width:40px;height:1px;background-color:var(--color-border);opacity:.5;transform:translateY(-50%)}.hero-subtitle:before{left:-50px}.hero-subtitle:after{right:-50px}.hero-description{font-size:clamp(1rem,2.5vw,1.25rem);max-width:600px;margin:0 auto 3rem;color:var(--color-text-light);line-height:1.6;text-align:center;font-weight:300;padding:0 .5rem}.hero-scroll-hint{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--color-text-light);font-size:.875rem;animation:bounce 2s infinite;margin-top:2rem}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(10px)}}@media(max-width:768px){.hero-section{padding:.5rem}.hero-content{padding:0 1rem}.hero-title{font-size:2.75rem;padding-bottom:10px}.hero-title:after{height:2.5px}.hero-subtitle{font-size:1rem;margin:.5rem 0 1.75rem}.hero-subtitle:before,.hero-subtitle:after{width:30px}.hero-subtitle:before{left:-35px}.hero-subtitle:after{right:-35px}.hero-description{font-size:1.05rem;margin-bottom:2.5rem;padding:0}.hero-scroll-hint{margin-top:1.5rem}}@media(max-width:480px){.hero-section{min-height:90vh;padding:.5rem}.hero-content{padding:0 .75rem}.hero-title{font-size:2.25rem;padding-bottom:8px;line-height:1.15}.hero-title:after{height:2px}.hero-q{font-size:1.1em}.hero-subtitle{font-size:.85rem;margin:.5rem 0 1.5rem;letter-spacing:.06em}.hero-subtitle:before,.hero-subtitle:after{display:none}.hero-description{font-size:1rem;line-height:1.7;margin-bottom:2rem}.hero-scroll-hint{font-size:.8rem;margin-top:1rem}}@media(max-width:360px){.hero-title{font-size:2rem;padding-bottom:6px}.hero-subtitle{font-size:.8rem}.hero-description{font-size:.95rem;line-height:1.75}}@media(max-height:600px)and (orientation:landscape){.hero-section{min-height:100vh;padding:2rem 1rem}.hero-title{font-size:2.5rem;margin-bottom:.25rem}.hero-subtitle{margin:.25rem 0 1rem}.hero-description{margin-bottom:1.5rem;font-size:1rem}.hero-scroll-hint{margin-top:1rem}}@media(max-width:320px){.hero-title{font-size:1.85rem}.hero-subtitle{font-size:.75rem}.hero-description{font-size:.9rem}}.about-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-bottom:4rem}.about-card{padding:2rem;border:1px solid var(--color-border);border-radius:8px;transition:all .3s ease}.about-card:hover{border-color:var(--color-primary);transform:translateY(-4px)}.about-card-icon{font-size:2rem;margin-bottom:1rem}.about-statement{max-width:800px;margin:0 auto;padding:3rem;background:var(--color-bg-light);border-left:3px solid var(--color-primary);position:relative}.statement-quote{font-size:4rem;position:absolute;top:-1rem;left:1rem;color:var(--color-primary);opacity:.2}.projects-showcase{display:flex;flex-direction:column;gap:3rem;margin-bottom:3rem}.work-note{text-align:center;max-width:600px;margin:0 auto;padding:2rem;font-style:italic;color:var(--color-text-light);border-top:1px solid var(--color-border)}.services-list{display:flex;flex-direction:column;gap:2rem}.service-item{padding:2.5rem;border:1px solid var(--color-border);border-radius:8px;transition:all .3s ease}.service-item:hover{border-color:var(--color-primary);background:var(--color-bg-light)}.service-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.service-indicator{font-size:1.5rem;color:var(--color-primary);transition:transform .3s ease}.service-item:hover .service-indicator{transform:translate(10px)}.service-details{margin-top:1.5rem;padding-left:1.5rem}.contact-method{display:flex;gap:2rem;align-items:flex-start;margin:3rem 0;padding:2rem;border:1px solid var(--color-border);border-radius:8px}.contact-icon{font-size:2rem}.contact-link{font-size:1.5rem;font-weight:600;color:var(--color-primary);text-decoration:none;display:block;margin:.5rem 0 1rem}.contact-principles{margin-top:3rem;padding:2rem;background:var(--color-bg-light);border-radius:8px}@media(max-width:768px){.section{padding:4rem 1rem}.hero-title{font-size:3rem}.line-subtitle{font-size:1.25rem}.about-grid{grid-template-columns:1fr}.about-card,.service-item{padding:1.5rem}.contact-method{flex-direction:column;gap:1rem}}.contact-methods{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin:3rem 0}.contact-method{display:flex;gap:1.5rem;align-items:flex-start;padding:2rem;border:1px solid var(--color-border);border-radius:8px;transition:all .3s ease;background:var(--color-bg)}.contact-method:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.contact-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--color-bg-light);flex-shrink:0;color:var(--color-primary)}.contact-icon svg{width:24px;height:24px}.contact-link{font-size:1.25rem;font-weight:600;color:var(--color-primary);text-decoration:none;display:block;margin:.5rem 0 1rem;transition:color .2s ease}.contact-link:hover{color:var(--color-secondary);text-decoration:underline}.contact-note{color:var(--color-text-light);margin:0;font-size:.95rem;line-height:1.5}.contact-method:nth-child(2) .contact-icon{background:linear-gradient(135deg,#25d366,#128c7e);color:#fff}.contact-method:nth-child(2) .contact-link{color:#128c7e}.contact-method:nth-child(2):hover{border-color:#25d366}@media(max-width:768px){.contact-methods{grid-template-columns:1fr;gap:1.5rem}.contact-method{padding:1.5rem;gap:1rem}.contact-icon{width:40px;height:40px}.contact-icon svg{width:20px;height:20px}.contact-link{font-size:1.1rem}}@media(max-width:480px){.contact-method{padding:1.25rem;flex-direction:column;align-items:center;text-align:center}.contact-icon{margin-bottom:.5rem}}.project-card[data-astro-cid-mspuyifq]{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;padding:2rem 0;border-bottom:1px solid var(--color-border)}.project-card[data-astro-cid-mspuyifq]:last-child{border-bottom:none}.project-image[data-astro-cid-mspuyifq]{border-radius:4px;overflow:hidden}.project-image[data-astro-cid-mspuyifq] img[data-astro-cid-mspuyifq]{width:100%;height:auto;display:block}.project-type[data-astro-cid-mspuyifq]{display:block;font-size:.875rem;color:var(--color-text-light);margin-bottom:.5rem}@media(max-width:768px){.project-card[data-astro-cid-mspuyifq]{grid-template-columns:1fr;gap:1.5rem}}
