/*! tailwindcss v4.1.17 | MIT License | https://tailwindcss.com */@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial}}}.topographic-bg{background-color:#101318;min-height:100vh;position:relative;overflow:hidden}.topographic-bg:before,.topographic-bg:after{content:"";background-image:repeating-radial-gradient(circle at 20% 30%,#0000 0 8px,#6496b414 8px 9px),repeating-radial-gradient(circle at 80% 70%,#0000 0 12px,#5082a00f 12px 13px),repeating-radial-gradient(circle,#0000 0 15px,#5a8caa0d 15px 16px),repeating-radial-gradient(circle at 65% 40%,#0000 0 20px,#4678960a 20px 21px),linear-gradient(135deg,#14283c66,#0a192899);background-size:600px 600px,800px 800px,1000px 1000px,1200px 1200px,100% 100%;animation:120s linear infinite topographicScroll;position:absolute;inset:-50%}.topographic-bg:after{opacity:.7;background-image:repeating-radial-gradient(circle at 40% 60%,#0000 0 10px,#3c6e8c0f 10px 11px),repeating-radial-gradient(circle at 90% 20%,#0000 0 18px,#3264820a 18px 19px),repeating-radial-gradient(circle at 30% 80%,#0000 0 14px,#4678960d 14px 15px);background-size:700px 700px,900px 900px,1100px 1100px;animation:100s linear infinite topographicScrollReverse,8s ease-in-out infinite topographicPulse}@keyframes topographicScroll{0%{transform:translate(0)rotate(0)}to{transform:translate(-50px,-50px)rotate(1deg)}}@keyframes topographicScrollReverse{0%{transform:translate(0)rotate(0)}to{transform:translate(30px,40px)rotate(-.5deg)}}@keyframes topographicPulse{0%,to{opacity:.7}50%{opacity:.85}}.topographic-bg-svg{background-color:#101318;background-image:url(/assets/hp-bg.svg);background-position:50%;background-repeat:repeat;background-size:800px 800px;min-height:100vh;animation:80s linear infinite topographicSvgScroll;position:relative;overflow:hidden}@keyframes topographicSvgScroll{0%{background-position:0 0}to{background-position:800px 800px}}.topographic-bg-svg:before{content:"";pointer-events:none;background:radial-gradient(#0000,#0a141e4d 60%,#050f1999);animation:10s ease-in-out infinite topographicPulse;position:absolute;inset:0}.topographic-content{z-index:1;color:hsl(var(--map-paper,30 10% 98%));position:relative}.topographic-bg-warm{background-color:#1d1a16}.topographic-bg-warm:before{background-image:repeating-radial-gradient(circle at 25% 35%,#0000 0 8px,#78645014 8px 9px),repeating-radial-gradient(circle at 75% 65%,#0000 0 12px,#6455460f 12px 13px),linear-gradient(135deg,#281e1466,#19140f99)}.topographic-bg-cool{background-color:#0f1419}.topographic-bg-cool:before{background-image:repeating-radial-gradient(circle at 30% 25%,#0000 0 8px,#5064821a 8px 9px),repeating-radial-gradient(circle at 70% 75%,#0000 0 12px,#3c557814 12px 13px),linear-gradient(135deg,#0f192880,#0a0f1eb3)}@media(prefers-reduced-motion:reduce){.topographic-bg:before,.topographic-bg:after,.topographic-bg-svg,.topographic-bg-svg:before{animation:none}}@media(max-width:768px){.topographic-bg:before,.topographic-bg:after{background-size:400px 400px,500px 500px,600px 600px,700px 700px,100% 100%}.topographic-bg-svg{background-size:500px 500px}}[data-theme=dark] .topographic-bg{background-color:#0c0e12}[data-theme=light] .topographic-bg{background-color:#fafaf9}[data-theme=light] .topographic-bg:before{background-image:repeating-radial-gradient(circle at 20% 30%,#0000 0 8px,#64788c08 8px 9px),repeating-radial-gradient(circle at 80% 70%,#0000 0 12px,#50647805 12px 13px),linear-gradient(135deg,#f0f5facc,#fafafce6)}.topographic-glow:before{filter:drop-shadow(0 0 20px #6496c826)}.topographic-bg-gradient{background:linear-gradient(135deg,#0f1319,#141a1f,#12191c) 0 0/200% 200%;animation:30s infinite gradientShift;position:relative}@keyframes gradientShift{0%,to{background-position:0%}50%{background-position:100%}}.invisible{visibility:hidden}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.container{width:100%}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}@layer base{:root{--map-water-deep:200 75% 22%;--map-water:195 80% 40%;--map-river:190 85% 52%;--map-forest:140 40% 22%;--map-moss:110 30% 36%;--map-fern:150 45% 46%;--map-sand:35 30% 68%;--map-stone:220 6% 56%;--map-muted:210 10% 46%;--map-ink:220 14% 8%;--map-paper:30 10% 98%;--brand-black:220 8% 6%;--brand-gold:44 90% 54%;--brand-gold-muted:44 90% 60%}[data-theme=dark]{--map-water-deep:200 70% 18%;--map-water:195 75% 30%;--map-river:190 80% 40%;--map-forest:140 30% 18%;--map-moss:110 25% 28%;--map-fern:150 35% 34%;--map-sand:35 20% 24%;--map-stone:220 8% 42%;--map-muted:210 10% 68%;--map-ink:220 12% 96%;--map-paper:220 10% 6%;--brand-gold:44 90% 48%;--brand-gold-muted:44 90% 56%}[data-theme=dark] body{background-color:#0c0e12}.palette-row{flex-wrap:wrap;align-items:center;gap:.5rem;margin:.5rem 0;display:flex}.palette-swatch{border:1px solid #0000000f;border-radius:6px;width:40px;height:28px;box-shadow:0 1px 2px #00000014}.bg-water{background-color:hsl(var(--map-water));color:#fff}.bg-forest{background-color:hsl(var(--map-forest));color:#fff}.bg-moss{background-color:hsl(var(--map-moss));color:#fff}.bg-sand{background-color:hsl(var(--map-sand));color:var(--map-ink)}.text-stone{color:hsl(var(--map-stone))}.text-water-deep{color:hsl(var(--map-water-deep))}.text-gold{color:hsl(var(--brand-gold))}.text-gold-subtle{color:hsl(var(--brand-gold)/.92)}.bg-gold-subtle{background-color:hsl(var(--brand-gold-muted)/.1)}.border-gold-subtle{border-color:hsl(var(--brand-gold)/.18)}.text-black-strong{color:hsl(var(--brand-black))}.underline-gold-hover:hover{text-decoration:underline;text-decoration-color:hsl(var(--brand-gold));text-decoration-thickness:2px}*{box-sizing:border-box;color:hsl(var(--map-ink,220 12% 96%));margin:0;padding:0;font-family:Roboto,sans-serif}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media(hover:none)and (pointer:coarse){a,button,.btn{-webkit-tap-highlight-color:#0000001a}a,button{min-width:44px;min-height:44px}}html,body,#root{height:100%}#root{z-index:0;flex-direction:column;min-height:100vh;display:flex;position:relative}.page-root{z-index:1;flex-direction:column;flex:1 0 auto;min-height:0;display:flex;position:relative}body{background-color:#101318;flex-direction:column;min-height:100vh;display:flex;position:relative;overflow-x:hidden}body:before,body:after{content:"";z-index:-1;pointer-events:none;background-image:repeating-radial-gradient(circle at 20% 30%,#0000 0 8px,#6496b414 8px 9px),repeating-radial-gradient(circle at 80% 70%,#0000 0 12px,#5082a00f 12px 13px),repeating-radial-gradient(circle,#0000 0 15px,#5a8caa0d 15px 16px),repeating-radial-gradient(circle at 65% 40%,#0000 0 20px,#4678960a 20px 21px),linear-gradient(135deg,#14283c66,#0a192899);background-size:600px 600px,800px 800px,1000px 1000px,1200px 1200px,100% 100%;animation:120s linear infinite topographicScroll;position:fixed;inset:-50%}body:after{opacity:.7;background-image:repeating-radial-gradient(circle at 40% 60%,#0000 0 10px,#3c6e8c0f 10px 11px),repeating-radial-gradient(circle at 90% 20%,#0000 0 18px,#3264820a 18px 19px),repeating-radial-gradient(circle at 30% 80%,#0000 0 14px,#4678960d 14px 15px);background-size:700px 700px,900px 900px,1100px 1100px;animation:100s linear infinite topographicScrollReverse,8s ease-in-out infinite topographicPulse}main{flex-direction:column;flex:1 0 auto;display:flex}main.page,.page{min-height:0;color:inherit;background:0 0;flex:1 0 auto}.page-inner{max-width:1100px;margin:0 auto;padding:2rem 1rem}.container{max-width:1100px;margin:0 auto;padding:0 16px}@media(prefers-reduced-motion:reduce){body:before,body:after{animation:none}}@media(max-width:768px){body:before,body:after{background-size:400px 400px,500px 500px,600px 600px,700px 700px,100% 100%}.container{padding:0 12px}.page-inner{padding:1.5rem .75rem}}@media(max-width:480px){.container{padding:0 8px}.page-inner{padding:1.25rem .5rem}h1{font-size:clamp(1.75rem,5vw,2.5rem)}h2{font-size:clamp(1.5rem,4vw,2rem)}h3{font-size:clamp(1.25rem,3.5vw,1.75rem)}p{font-size:clamp(.9375rem,3vw,1rem);line-height:1.6}}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@keyframes earthyGradient{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}header{position:relative;padding:12px 0;margin-bottom:16px;border:1px solid #e5e7eb;border-bottom:none;border-radius:0 0 12px 12px;box-shadow:0 8px 20px #0000000f;background:linear-gradient(-45deg,hsl(var(--map-water)),hsl(var(--map-river)),hsl(var(--map-forest)),hsl(var(--map-fern)),hsl(var(--map-moss)),hsl(var(--map-water-deep)));background-size:400% 400%;animation:none!important}header .container{max-width:none;padding:0}header .navbar{padding:2px 80px 2px 30px}.navbar{display:flex;justify-content:space-between;align-items:center;padding:0;box-shadow:none;background:transparent}.header{position:relative;z-index:1;overflow:visible;color:hsl(var(--map-paper));transition:background-color .3s ease,background-image .3s ease,color .3s ease;background:hsl(var(--map-water)) linear-gradient(135deg,hsl(var(--map-water)),hsl(var(--map-fern)));animation:none!important}.header:after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,#0000000f,#0000);border-radius:inherit;mix-blend-mode:multiply;transition:opacity .3s ease}.header--water{background-image:linear-gradient(135deg,hsl(var(--map-water)),hsl(var(--map-fern)));background-color:hsl(var(--map-water))}.header--water-deep{background-image:linear-gradient(135deg,hsl(var(--map-water-deep)),hsl(var(--map-moss)));background-color:hsl(var(--map-water-deep))}.header--forest{background-image:linear-gradient(135deg,hsl(var(--map-forest)),hsl(var(--map-stone)) 60%,hsl(var(--map-sand)));background-color:hsl(var(--map-forest))}.header a,.header .nav-links a,.header .logo{color:inherit}.header--overlay:after{background:linear-gradient(180deg,#0000000f,#0000);mix-blend-mode:multiply}.nav-links{list-style:none;display:flex;gap:2rem}.nav-links a{text-decoration:none;font-weight:600;color:#0c0c0c;padding:.25rem .375rem;transition:color .15s ease;cursor:pointer}.nav-links a.active{font-weight:600;color:hsl(var(--brand-gold))}.nav-links a:hover{color:hsl(var(--brand-gold))}.header .nav-links a{color:inherit;padding:.25rem .5rem;border-radius:6px;position:relative;transition:color .18s ease,background-color .18s ease,box-shadow .18s ease}.header .nav-links a:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:0;height:2px;background:hsl(var(--brand-gold));transition:width .2s ease}.header .nav-links a:hover,.header .nav-links a:focus{color:hsl(var(--brand-gold));background:hsl(var(--brand-gold-muted) / .15);box-shadow:0 4px 12px hsl(var(--brand-gold) / .2);outline:none}.header .nav-links a:hover:after,.header .nav-links a:focus:after{width:80%}.header .nav-links a.active{color:hsl(var(--brand-gold));font-weight:600}.header .nav-links a.active:after{width:80%}.header .nav-links a:focus{box-shadow:0 0 0 3px hsl(var(--brand-gold) / .3),0 4px 12px hsl(var(--brand-gold) / .2)}.logo{position:static;top:auto;right:auto;transform:none;display:flex;align-items:center;gap:.5rem;margin-left:0}.logo img{height:40px;width:auto;display:block;margin-right:0}.logo .brand{display:inline-flex;align-items:center;gap:.5rem;color:inherit;text-decoration:none;margin-left:0}.logo .brand{transition:all .2s ease}.logo .brand:hover,.logo .brand:focus{color:hsl(var(--brand-gold));text-shadow:0 1px 0 rgba(0,0,0,.08);transform:scale(1.02)}.logo img{filter:drop-shadow(0 2px 4px rgba(0,0,0,.12));transition:filter .2s ease}.logo .brand:hover img,.logo .brand:focus img{filter:drop-shadow(0 4px 8px hsl(var(--brand-gold) / .4))}@media(prefers-reduced-motion:reduce){header,.header,.header:before,.header:after{animation:none!important;transition:none!important}.header:before,.header:after{opacity:1}}.mobile-menu-toggle{display:none;flex-direction:column;justify-content:space-around;width:40px;height:40px;background:transparent;border:none;cursor:pointer;padding:8px;z-index:1000;transition:transform .3s ease}.mobile-menu-toggle:hover{transform:scale(1.05)}.mobile-menu-toggle:focus{outline:2px solid hsl(var(--brand-gold));outline-offset:2px}.hamburger-line{width:100%;height:3px;background-color:hsl(var(--map-ink));border-radius:2px;transition:all .3s ease}.mobile-menu-toggle.active .hamburger-line:nth-child(1){transform:translateY(9px) rotate(45deg)}.mobile-menu-toggle.active .hamburger-line:nth-child(2){opacity:0;transform:translate(-20px)}.mobile-menu-toggle.active .hamburger-line:nth-child(3){transform:translateY(-9px) rotate(-45deg)}@media(max-width:768px){header .navbar{padding:2px 20px}.mobile-menu-toggle{display:flex}.mobile-menu-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:998;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.nav-links{position:fixed;top:0;right:-100%;width:280px;max-width:85vw;height:100vh;background:linear-gradient(180deg,hsl(var(--map-water)),hsl(var(--map-fern)));flex-direction:column;padding:80px 20px 20px;gap:.5rem;box-shadow:-5px 0 25px #00000026;transition:right .4s cubic-bezier(.68,-.55,.265,1.55);z-index:999;overflow-y:auto}.nav-links.mobile-open{right:0}.nav-links li{width:100%;margin:0}.nav-links a{display:block;width:100%;padding:1rem 1.25rem;font-size:1.125rem;color:hsl(var(--map-paper));border-radius:8px;transition:all .2s ease}.nav-links a:hover,.nav-links a:focus{background:#ffffff26;color:hsl(var(--brand-gold));transform:translate(5px)}.nav-links a.active{background:#fff3;color:hsl(var(--brand-gold));font-weight:700;border-left:4px solid hsl(var(--brand-gold))}.header .nav-links a{color:hsl(var(--map-paper))}.header .nav-links a:after{display:none}.logo img{height:36px}}@media(max-width:480px){header .navbar{padding:2px 15px}.nav-links{width:260px;padding:70px 15px 15px}.nav-links a{padding:.875rem 1rem;font-size:1.05rem}.logo img{height:32px}}body.mobile-menu-open{overflow:hidden}.footer{background-color:hsl(var(--map-water-deep));color:hsl(var(--map-paper));text-align:center;padding:1rem 0;margin-top:auto;border-top:3px solid hsl(var(--brand-gold) / .4);position:relative}.footer .container{display:flex;justify-content:space-between;align-items:center;gap:1rem}.social-links{display:flex;gap:1.25rem;list-style:none;margin:0;padding:0;align-items:center}.social-links li{display:inline-flex}.social-links a{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:8px;color:#fff;text-decoration:none;background:#ffffff26;transition:all .2s ease;border:2px solid hsl(var(--brand-gold) / .3)}.social-links a:hover,.social-links a:focus{background:hsl(var(--brand-gold) / .2);border-color:hsl(var(--brand-gold) / .8);transform:translateY(-3px) scale(1.05);box-shadow:0 6px 20px hsl(var(--brand-gold) / .4);outline:none}.social-links a:active{transform:translateY(-1px) scale(1.02)}.social-links svg{fill:currentColor;width:22px;height:22px;border-radius:0}.footer p{margin:0;color:hsl(var(--map-paper) / .9);text-shadow:0 1px 2px hsl(var(--brand-gold) / .1)}@media(max-width:700px){.footer .container{flex-direction:column;gap:.5rem}}.btn{display:inline-block;padding:.85rem 2rem;text-decoration:none;border-radius:999px;transition:all .2s ease;border:none;cursor:pointer;font-weight:500;font-size:1rem}.btn:hover,.btn:focus{transform:translateY(-2px);box-shadow:0 8px 20px #00000026;outline:none}.btn:active{transform:translateY(0)}.btn-primary{background-color:#047857;color:#fff}.btn-primary:hover{background-color:#065f46}.btn-primary:focus{box-shadow:0 0 0 4px #04785733,0 8px 20px #00000026}.btn-secondary{background-color:#fff;border:2px solid #047857;color:#047857}.btn-secondary:hover{background-color:#f0fdf4;border-color:#065f46;color:#065f46}.btn-secondary:focus{box-shadow:0 0 0 4px #04785726,0 8px 20px #0000001a}.btn-primary--gold{background-color:hsl(var(--brand-black));color:hsl(var(--brand-gold));border:2px solid hsl(var(--brand-gold) / .3)}.btn-primary--gold:hover{background-color:hsl(var(--brand-black));color:hsl(var(--brand-gold));border-color:hsl(var(--brand-gold) / .5)}.btn-primary--gold:focus{box-shadow:0 0 0 4px hsl(var(--brand-gold) / .15),0 8px 20px #00000026}@media(max-width:600px){.btn{width:100%;padding:.75rem 1.5rem;text-align:center}}.hero-section{position:relative;width:100%;padding:2.5rem 0;display:flex;align-items:center;justify-content:center;background:transparent}.hero-container{position:relative;width:min(1200px,calc(100% - 48px));margin:0 auto;padding:0 24px;box-sizing:border-box}.hero-overlay{position:absolute;inset:0;pointer-events:none}.hero-content-card{position:relative;z-index:1;background:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:16px;padding:3rem 2.8rem;box-shadow:0 8px 32px #00000014,0 2px 8px #0000000a,inset 0 1px #ffffff80;border:1px solid rgba(255,255,255,.4);max-width:900px;margin:0 auto}@media(max-width:600px){.hero-content-card{padding:2rem 1.5rem;border-radius:20px}}@media(max-width:600px){.hero-section{padding:1.75rem 0}.hero-container{padding:0 16px}.hero-title{font-size:clamp(1.75rem,6vw,2.25rem);margin-bottom:.75rem}.hero-lede{font-size:1rem}.hero-subtext{font-size:.95rem}}.hero-title{font-size:clamp(2rem,4vw,3rem);font-weight:700;color:#0f172a;margin-bottom:1rem}.hero-accent{color:#0ea5e9}.hero-lede{color:#475569;font-size:1.05rem;line-height:1.6}.hero-subtext{margin-top:1rem;color:#4b5563;font-size:1rem;line-height:1.6}.hero-cta{margin-top:1.25rem;display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem}.tech-stack-marquee-section{width:100%;padding:3rem 0;background:linear-gradient(180deg,#f8fafccc,#fff9);overflow:hidden}.tech-stack-marquee-container{max-width:1400px;margin:0 auto;padding:0 2rem}.tech-stack-title{text-align:center;font-size:.875rem;font-weight:700;color:#0f172a;margin-bottom:2rem;text-transform:uppercase;letter-spacing:1px;opacity:.7}.marquee-wrapper{position:relative;width:100%;overflow:hidden;padding:1.5rem 0}.marquee-wrapper:before,.marquee-wrapper:after{content:"";position:absolute;top:0;width:150px;height:100%;z-index:2;pointer-events:none}.marquee-wrapper:before{left:0;background:linear-gradient(to right,#f8fafc,#f8fafc00)}.marquee-wrapper:after{right:0;background:linear-gradient(to left,#f8fafc,#f8fafc00)}.marquee-content{display:flex;gap:3rem;animation:scroll 40s linear infinite;width:-moz-fit-content;width:fit-content}@keyframes scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.marquee-wrapper:hover .marquee-content{animation-play-state:paused}.tech-item{display:flex;flex-direction:column;align-items:center;gap:.5rem;min-width:80px;padding:1rem;border-radius:12px;background:#fff9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(226,232,240,.8);transition:all .3s ease;cursor:pointer}.tech-item:hover{transform:translateY(-8px) scale(1.05);background:#fffffff2;box-shadow:0 12px 40px #0000001f,0 4px 12px #00000014;border-color:var(--tech-color, #0ea5e9)}.tech-icon{width:48px;height:48px;-o-object-fit:contain;object-fit:contain;filter:grayscale(0%) opacity(.9);transition:all .3s ease}.tech-item:hover .tech-icon{filter:grayscale(0%) opacity(1) drop-shadow(0 4px 8px rgba(0,0,0,.15));transform:scale(1.1)}.tech-name{font-size:.75rem;font-weight:600;color:#475569;text-align:center;transition:color .3s ease;white-space:nowrap}.tech-item:hover .tech-name{color:var(--tech-color, #0ea5e9);font-weight:700}@media(max-width:768px){.tech-stack-marquee-section{padding:2rem 0}.tech-stack-marquee-container{padding:0 1rem}.tech-stack-title{font-size:.8125rem;margin-bottom:1.5rem}.marquee-content{gap:2rem;animation-duration:30s}.tech-item{min-width:70px;padding:.75rem}.tech-icon{width:40px;height:40px}.tech-name{font-size:.6875rem}.marquee-wrapper:before,.marquee-wrapper:after{width:80px}}@media(max-width:480px){.marquee-content{gap:1.5rem;animation-duration:25s}.tech-item{min-width:60px;padding:.625rem}.tech-icon{width:36px;height:36px}.tech-name{font-size:.625rem}}@media(prefers-reduced-motion:reduce){.marquee-content{animation:none}.marquee-wrapper{overflow-x:auto;scrollbar-width:thin}.marquee-content{justify-content:flex-start}}.featured-work-section{width:100%;padding:4rem 1.5rem;background:linear-gradient(180deg,#ffffff80,#f8fafccc)}.featured-work-container{max-width:1100px;margin:0 auto}.featured-work-header{margin-bottom:2.5rem}.featured-work-title{font-size:2rem;font-weight:700;color:hsl(var(--map-fern));margin-bottom:.75rem;text-align:left}.featured-work-subtitle{font-size:1.125rem;color:hsl(var(--map-muted));margin:0;text-align:left}.featured-projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));grid-auto-rows:auto;gap:1.5rem;align-items:start}.featured-work-footer{text-align:center;margin-top:3rem}.view-all-projects-link{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2rem;background:#ffffffe6;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#0ea5e9;font-size:1.125rem;font-weight:600;text-decoration:none;border-radius:12px;border:2px solid #0ea5e9;transition:all .3s ease}.view-all-projects-link:hover{background:#0ea5e9;color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px #0ea5e94d}.view-all-projects-link svg{transition:transform .3s ease}.view-all-projects-link:hover svg{transform:translate(4px)}@media(max-width:768px){.featured-work-section{padding:3rem 1rem}.featured-work-title{font-size:1.75rem;text-align:center}.featured-work-subtitle{font-size:1rem;text-align:center}.featured-projects-grid{grid-template-columns:1fr;gap:1.25rem}.project-card{padding:1.5rem}.project-card-link{width:100%;justify-content:center}.view-all-projects-link{font-size:1rem;padding:.875rem 1.5rem}}@media(max-width:480px){.featured-work-section{padding:2rem .75rem}.featured-work-header{margin-bottom:2rem}.featured-work-title{font-size:1.5rem}.featured-work-subtitle{font-size:.9375rem}.project-card{padding:1.25rem;border-radius:1rem}.project-card-header{flex-direction:column;align-items:flex-start;gap:.5rem}.project-card-title{font-size:1.125rem}.project-card-status{align-self:flex-start}.project-card-description{font-size:.9375rem;margin-bottom:1rem}.project-card-tags{margin-top:1rem}.project-card-tag{font-size:.8125rem;padding:.3rem .75rem}.project-card-link{margin-top:1rem;padding:.625rem 1.25rem;font-size:.875rem}.featured-work-footer{margin-top:2rem}.view-all-projects-link{width:100%;justify-content:center}}@media(max-width:600px){.hero-cta{flex-direction:column}}.home-page{display:flex;flex-direction:column;flex:1 0 auto;min-height:0;background:transparent}.projects-section{padding:4rem 1.5rem;max-width:1100px;margin:0 auto}.projects-heading{font-size:2rem;font-weight:700;color:hsl(var(--map-fern));margin-bottom:2.5rem;text-align:left}.project-domain{margin-bottom:3.5rem}.project-domain:last-child{margin-bottom:0}.domain-heading{font-size:1.5rem;font-weight:600;color:hsl(var(--map-river));margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid rgba(16,185,129,.2)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));grid-auto-rows:auto;gap:1.5rem;align-items:start}.project-card{background-color:#fff;border-radius:1.25rem;box-shadow:0 15px 35px #0f172a14;padding:1.75rem;transition:transform .18s ease,box-shadow .18s ease;display:flex;flex-direction:column;height:100%}.project-card:hover{transform:translateY(-6px);box-shadow:0 25px 45px #0f172a1f}.project-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.75rem}.project-card-title{font-size:1.25rem;font-weight:600;color:hsl(var(--map-water-deep, 197 100% 28%));margin:0;flex:1}.project-card-status{padding:.35rem .75rem;background-color:#3b82f61a;color:#2563eb;font-size:.75rem;font-weight:500;border-radius:999px;white-space:nowrap;flex-shrink:0}.project-card-description{color:#4b5563;margin-top:0;margin-bottom:1.25rem;line-height:1.6;flex-grow:1}.project-card-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.25rem}.project-card-tag{padding:.35rem .85rem;background-color:#10b98126;color:#047857;font-size:.85rem;border-radius:999px}.project-card-link{display:inline-flex;align-items:center;gap:.5rem;margin-top:1.25rem;padding:.75rem 1.5rem;background-color:#047857;color:#fff;text-decoration:none;border-radius:999px;font-size:.9rem;font-weight:500;transition:all .2s ease;align-self:flex-start}.project-card-link:hover{background-color:#065f46;transform:translateY(-2px);box-shadow:0 8px 20px #00000026}.project-card-link:focus{outline:none;box-shadow:0 0 0 4px #04785733,0 8px 20px #00000026}.project-card-link:active{transform:translateY(0)}.github-icon{flex-shrink:0}.projects-page{min-height:100%;color:inherit;background:transparent}.project-card img{width:100%;height:160px;-o-object-fit:cover;object-fit:cover;border-radius:6px;margin-bottom:.75rem}.project-card .title{font-size:1.05rem;font-weight:600;margin-bottom:.35rem}.project-card .meta{font-size:.9rem;color:#666;margin-bottom:.75rem}.project-card .links{display:flex;gap:.5rem;justify-content:center;margin-top:.5rem}.projects{max-width:1100px;margin:0 auto;padding:1px 1rem}.project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-top:2rem}.project-card{background-color:#fff;border-radius:.75rem;box-shadow:0 4px 8px #0000001a;padding:1.5rem;text-align:center;transition:transform .15s ease}.project-card:hover{transform:translateY(-5px)}@media(max-width:768px){.projects{padding:1px .75rem}.project-grid{grid-template-columns:1fr;gap:1.5rem;margin-top:1.5rem}.project-card{padding:1.25rem}.project-card img{height:180px}}@media(max-width:480px){.projects{padding:1px .5rem}.project-grid{gap:1.25rem}.project-card{padding:1rem}.project-card img{height:160px;border-radius:4px}.project-card .title{font-size:1rem}.project-card .meta{font-size:.85rem}.project-card .links{flex-direction:column;gap:.5rem}.project-card .links a{width:100%;text-align:center;padding:.5rem}}.page-about{min-height:100%;color:inherit;background:transparent;padding:3rem 1.5rem}.page-about .page-inner{max-width:900px;margin:0 auto}.page-about section{margin-bottom:3rem}.page-about section:last-child{margin-bottom:0}.page-about h2{font-size:2rem;font-weight:700;color:hsl(var(--map-fern));margin-bottom:1rem;line-height:1.2}.page-about p{font-size:1.05rem;line-height:1.7;color:hsl(var(--map-muted));margin-bottom:1rem}.page-about .intro{display:flex;gap:1.25rem;align-items:center;flex-wrap:wrap}.page-about .intro img{width:160px;height:auto;border-radius:8px;-o-object-fit:cover;object-fit:cover;box-shadow:0 6px 18px #00000014}@media(max-width:600px){.page-about{padding:2rem 1rem}.page-about .intro{flex-direction:column;align-items:flex-start}.page-about .intro img{width:120px}.page-about h2{font-size:1.75rem}.page-about p{font-size:1rem}}.contact-page{min-height:100%;color:inherit;background:transparent}.contact{padding:3rem 1.5rem}.contact .page-inner{max-width:700px;margin:0 auto}.contact-info{text-align:center;margin-bottom:3rem}.contact-info h2{font-size:2.5rem;font-weight:700;color:hsl(var(--map-fern));margin-bottom:1rem}.contact-info p{font-size:1.1rem;line-height:1.7;color:hsl(var(--map-muted));max-width:600px;margin:0 auto}.contact-email-link{color:hsl(var(--map-fern));font-weight:600;text-decoration:none;transition:color .2s ease}.contact-email-link:hover{color:hsl(var(--map-river));text-decoration:underline}.contact-form{background:#fff;border-radius:1.25rem;padding:2.5rem;box-shadow:0 20px 50px #00000014}.contact-form form{display:grid;gap:1.5rem}.contact-form label{font-size:.95rem;font-weight:600;color:#1f2937;display:block;margin-bottom:.5rem}.contact input,.contact textarea{width:100%;padding:.875rem 1rem;border:2px solid #e5e7eb;border-radius:.5rem;font:inherit;font-size:1rem;transition:all .2s ease;background-color:#fff}.contact input:hover,.contact textarea:hover{border-color:#d1d5db}.contact input:focus,.contact textarea:focus{outline:none;border-color:#047857;box-shadow:0 0 0 4px #0478571a;background-color:#f9fafb}.contact textarea{min-height:150px;resize:vertical;font-family:inherit}.contact-form .btn{margin-top:.5rem;width:100%;font-size:1.05rem}@media(max-width:700px){.contact{padding:2rem 1rem}.contact-info h2{font-size:2rem}.contact-info p{font-size:1rem}.contact-form{padding:1.75rem}}@media(max-width:500px){.contact-form{padding:1.25rem;border-radius:1rem}.contact-info{margin-bottom:2rem}}
