@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:200 800;font-display:swap;src:url(../media/0b1dc8ddaa74ba49-s.04o39dzmj.ey..woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:200 800;font-display:swap;src:url(../media/e629b5bc06499d58-s.0b_~8bw~gzh90.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:200 800;font-display:swap;src:url(../media/1a099d89ee94ee96-s.0_qb~~5cn13jl.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:200 800;font-display:swap;src:url(../media/fba5a26ea33df6a3-s.p.0eehd8tgys7nv.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Plus Jakarta Sans Fallback;src:local(Arial);ascent-override:98.88%;descent-override:21.15%;line-gap-override:0.0%;size-adjust:104.98%}.plus_jakarta_sans_869a8f48-module__MQI6JW__className{font-family:Plus Jakarta Sans,Plus Jakarta Sans Fallback;font-style:normal}.plus_jakarta_sans_869a8f48-module__MQI6JW__variable{--font-plus-jakarta-sans:"Plus Jakarta Sans", "Plus Jakarta Sans Fallback"}
*{box-sizing:border-box;font-family:var(--Font-B612);margin:0;padding:0}:root{--Font-PlusJakarta:var(--font-plus-jakarta-sans), "Plus Jakarta Sans", sans-serif;--Font-B612:var(--Font-PlusJakarta);--Font-Space:var(--Font-PlusJakarta);--Color-1:#f5f5f7;--Color-2:#e8e8ed;--Color-3:#1d1d1f;--Color-Accent:#d01414;--Color-Accent-Light:#f33;--Color-Accent-Glow:#d0141440;--Color-Surface:#fff9;--Color-Surface-Border:#ffffff4d;--Color-Section-Base:#f5f5f7d1;--Color-Section-Alt:#e8e8edc7;--Shadow-Sm:0 2px 8px #00000014;--Shadow-Md:0 4px 20px #0000001f;--Shadow-Lg:0 8px 40px #00000029;--Transition-Fast:.2s;--Transition-Med:.35s;--Transition-Slow:.5s;--Radius-Sm:12px;--Radius-Md:20px;--Radius-Lg:28px}body.dark-mode{--Color-1:#0d0d0d;--Color-2:#1a1a1a;--Color-3:#f0f0f2;--Color-Accent:#f44;--Color-Accent-Light:#f66;--Color-Accent-Glow:#ff44444d;--Color-Surface:#28282899;--Color-Surface-Border:#ffffff14;--Color-Section-Base:#0d0d0dd1;--Color-Section-Alt:#1a1a1ac7;--Shadow-Sm:0 2px 8px #0000004d;--Shadow-Md:0 4px 20px #0006;--Shadow-Lg:0 8px 40px #00000080}html{scroll-behavior:smooth;scroll-padding-top:80px}body{background:var(--Color-1);color:var(--Color-3);isolation:isolate;min-height:100vh;transition:background var(--Transition-Med) ease, color var(--Transition-Med) ease;line-height:1.6;position:relative;overflow-x:hidden}.site-background{z-index:0;pointer-events:none;position:fixed;inset:0;overflow:hidden}.site-background canvas{opacity:.46;width:100%!important;height:100%!important}body.dark-mode .site-background canvas{opacity:.54}.site-background-fallback{z-index:0;pointer-events:none;background:radial-gradient(circle at 18% 25%,#d0141417,#0000 45%),radial-gradient(circle at 80% 70%,#d0141412,#0000 48%);position:fixed;inset:0}.site-shell{z-index:1;position:relative}@media (prefers-reduced-motion:reduce){.site-background canvas{opacity:.24}}body.loaded{animation:.5s fadeIn}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.glass-card{background:var(--Color-Surface);-webkit-backdrop-filter:blur(16px);border:1px solid var(--Color-Surface-Border);border-radius:var(--Radius-Md);box-shadow:var(--Shadow-Sm);transition:all var(--Transition-Med) ease}.glass-card:hover{box-shadow:var(--Shadow-Md);border-color:var(--Color-Accent-Glow)}.scroll-progress{background:linear-gradient(90deg, var(--Color-Accent), var(--Color-Accent-Light));z-index:9999;height:3px;box-shadow:0 0 12px var(--Color-Accent-Glow);transition:width 50ms linear;position:fixed;top:0;left:0}p,h3{text-align:center}h1,h2,h3{line-height:1.2}a{color:inherit;transition:color var(--Transition-Fast) ease;text-decoration:none}h2{text-align:center;color:var(--Color-3);margin-bottom:1rem;font-size:2rem;display:inline-block;position:relative}hr{background:linear-gradient(90deg, var(--Color-Accent), var(--Color-Accent-Light));width:4rem;height:3px;transition:width var(--Transition-Med) ease;border:none;border-radius:2px;margin:0 auto 2.5rem}section:hover hr{width:6rem}.section-subtitle{opacity:.7;max-width:500px;margin-bottom:2.5rem;font-size:1.05rem}.section{flex-direction:column;justify-content:center;align-items:center;min-height:25rem;padding:5rem 2rem;display:flex;position:relative}.observe-animation{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(30px)}.observe-animation.animate-in{opacity:1;transform:translateY(0)}.stagger-item{opacity:0;transition:opacity .4s,transform .4s;transform:translateY(20px)}.stagger-item.animate-in{opacity:1;transform:translateY(0)}.header{border-bottom:1px solid var(--Color-Surface-Border);background:var(--Color-Surface);-webkit-backdrop-filter:blur(20px);z-index:1000;min-height:4rem;transition:all var(--Transition-Med) ease;justify-content:space-between;align-items:center;padding:.875rem 2rem;display:flex;position:relative}.header.sticky{box-shadow:var(--Shadow-Md);animation:.3s slideDown;position:fixed;top:0;left:0;right:0}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.header-name{color:var(--Color-3);transition:color var(--Transition-Fast) ease, transform var(--Transition-Fast) ease;font-size:1.25rem;font-weight:700;display:inline-block}.header-name:hover{color:var(--Color-Accent);transform:scale(1.05)}.header-nav{justify-content:center;align-items:center;gap:1rem;display:flex;position:relative}.header-menu_open{cursor:pointer;z-index:1001;transition:all var(--Transition-Fast) ease;background-color:#0000;border:none;border-radius:8px;justify-content:center;align-items:center;padding:.5rem;display:flex}.header-menu_open:hover,.header-menu_open:focus{background-color:var(--Color-Surface);box-shadow:var(--Shadow-Sm)}.hamburger{flex-direction:column;gap:4px;width:28px;display:flex}.hamburger .line{background-color:var(--Color-3);width:100%;height:3px;transition:all var(--Transition-Med) ease;border-radius:2px}.header-menu_open.active .line:first-child{transform:rotate(45deg)translateY(10px)}.header-menu_open.active .line:nth-child(2){opacity:0;transform:translate(-20px)}.header-menu_open.active .line:nth-child(3){transform:rotate(-45deg)translateY(-10px)}.dark-mode-toggle{border:1px solid var(--Color-Surface-Border);background:var(--Color-Surface);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;width:44px;height:44px;transition:all var(--Transition-Med) ease;border-radius:50%;justify-content:center;align-items:center;padding:.5rem;font-size:1.25rem;display:flex;position:relative;overflow:hidden}.dark-mode-toggle:hover{box-shadow:var(--Shadow-Md);border-color:var(--Color-Accent);transform:scale(1.1)}.dark-mode-toggle.spin{animation:.3s spin}@keyframes spin{to{transform:rotate(360deg)}}.dark-mode-toggle .sun-icon,.dark-mode-toggle .moon-icon{transition:opacity var(--Transition-Med) ease, transform var(--Transition-Med) ease;position:absolute}body:not(.dark-mode) .dark-mode-toggle .moon-icon,body.dark-mode .dark-mode-toggle .sun-icon{opacity:0;transform:scale(0)}body.dark-mode .dark-mode-toggle .moon-icon{opacity:1;transform:scale(1)}.header-dropdown{z-index:999;background:var(--Color-Surface);-webkit-backdrop-filter:blur(20px);box-shadow:var(--Shadow-Lg);border-bottom:1px solid var(--Color-Surface-Border);flex-direction:column;animation:.3s slideDown;display:none;position:fixed;top:4rem;left:0;right:0}.header-dropdown.open{display:flex}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.header-dropdown li{border-bottom:1px solid var(--Color-Surface-Border);text-align:center;transition:all var(--Transition-Fast) ease;list-style-type:none}.header-dropdown li:last-child{border-bottom:none}.header-dropdown li a{color:var(--Color-3);letter-spacing:.5px;transition:all var(--Transition-Fast) ease;padding:1rem;font-size:.95rem;font-weight:500;display:block}.header-dropdown li a.active-link{color:var(--Color-Accent);font-weight:700}.header-dropdown li:hover,.header-dropdown li:focus-within{background-color:var(--Color-Accent)}.header-dropdown li:hover a,.header-dropdown li:focus-within a{color:#fff;padding-left:1.5rem}.header-cv_button{color:var(--Color-Accent)!important;font-weight:700!important}.header-dropdown li:hover .header-cv_button,.header-dropdown li:focus-within .header-cv_button{color:#fff!important}.intro{background:var(--Color-Section-Base);min-height:calc(100vh - 4rem);position:relative;overflow:hidden}.intro:before{content:"";background:radial-gradient(circle, var(--Color-Accent-Glow) 0%, transparent 70%);filter:blur(60px);width:60%;height:60%;animation:10s ease-in-out infinite pulse;position:absolute;top:-30%;right:-30%}.intro:after{content:"";filter:blur(60px);background:radial-gradient(circle,#d0141414 0%,#0000 70%);width:50%;height:50%;animation:12s ease-in-out infinite reverse pulse;position:absolute;bottom:-20%;left:-20%}@keyframes pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.8;transform:scale(1.15)}}.intro article{z-index:1;flex-direction:column;justify-content:center;align-items:center;gap:2rem;display:flex}.hero-text{text-align:center;animation:.8s fadeInUp}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.intro-text{color:var(--Color-3);margin:.5rem 0;font-size:1.2rem}.intro-text.greeting{opacity:.7;text-transform:uppercase;letter-spacing:2px;font-size:1rem;font-weight:400;animation:.8s .2s backwards fadeInUp}.intro-text.name{background:linear-gradient(135deg, var(--Color-3) 30%, var(--Color-Accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:700;animation:.8s .4s backwards fadeInUp}.intro-text.typing-text{color:var(--Color-Accent);border-right:3px solid var(--Color-Accent);font-size:1.5rem;font-weight:700;animation:.8s .6s backwards fadeInUp,.7s step-end infinite blink;display:inline-block}@keyframes blink{0%,to{border-color:#0000}50%{border-color:var(--Color-Accent)}}.tagline{opacity:.6;max-width:400px;margin-top:1rem;font-size:1rem;line-height:1.5;animation:.8s .8s backwards fadeInUp}.hero-cta-group{flex-wrap:wrap;justify-content:center;gap:1rem;margin-top:2rem;animation:.8s 1s backwards fadeInUp;display:flex}.hero-socials{justify-content:center;gap:1rem;margin-top:1.5rem;animation:.8s 1.2s backwards fadeInUp;display:flex}.hero-socials a{background:var(--Color-Surface);border:1px solid var(--Color-Surface-Border);width:40px;height:40px;transition:all var(--Transition-Med) ease;border-radius:50%;justify-content:center;align-items:center;display:flex}.hero-socials a:hover{background:var(--Color-Accent);border-color:var(--Color-Accent);box-shadow:0 4px 16px var(--Color-Accent-Glow);transform:translateY(-3px)}.hero-socials img{filter:brightness(0)saturate();transition:filter var(--Transition-Fast) ease}body.dark-mode .hero-socials img,.hero-socials a:hover img{filter:brightness(0)invert()}.hero-image{object-fit:contain;width:min(70vw,320px);height:auto;box-shadow:var(--Shadow-Lg);transition:all var(--Transition-Slow) ease;border:4px solid var(--Color-Accent);border-radius:30px;animation:1s 1s backwards fadeInScale}@keyframes fadeInScale{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.hero-image:hover{box-shadow:0 12px 40px var(--Color-Accent-Glow);transform:scale(1.05)rotate(3deg)}.services{background:var(--Color-Section-Alt)}.service-article-container{flex-direction:column;gap:1.5rem;width:100%;max-width:1200px;margin-bottom:2rem;display:flex}.services-article{background:var(--Color-Surface);-webkit-backdrop-filter:blur(12px);border-radius:var(--Radius-Md);box-shadow:var(--Shadow-Sm);transition:all var(--Transition-Med) ease;border:1px solid var(--Color-Surface-Border);flex-direction:column;align-items:center;padding:2rem;display:flex}.services-article:hover{box-shadow:var(--Shadow-Lg);border-color:var(--Color-Accent);transform:translateY(-6px)}.service-icon{transition:transform var(--Transition-Med) ease;margin-bottom:.75rem;font-size:2.5rem}.services-article:hover .service-icon{transform:scale(1.15)rotate(5deg)}.services-article h3{color:var(--Color-3);margin-bottom:.5rem;font-size:1.15rem}.services-article p{color:var(--Color-3);opacity:.75;font-size:.95rem;line-height:1.6}.service-details{text-align:left;width:100%;margin-top:1rem;list-style:none}.service-details li{opacity:.65;padding:.35rem 0 .35rem 1.2rem;font-size:.85rem;position:relative}.service-details li:before{content:"→";color:var(--Color-Accent);font-weight:700;position:absolute;left:0}.skills{background:var(--Color-Section-Base)}.skills-grid{flex-direction:column;gap:1.5rem;width:100%;max-width:1000px;display:flex}.skill-category{padding:2rem}.skill-category h3{color:var(--Color-Accent);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:1rem;font-size:1rem;font-weight:700}.skill-badges{flex-wrap:wrap;gap:.6rem;display:flex}.skill-badge{background:var(--Color-1);border:1px solid var(--Color-Surface-Border);color:var(--Color-3);transition:all var(--Transition-Med) ease;cursor:default;border-radius:50px;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.85rem;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.skill-badge:after{content:"";background:var(--Color-Accent);width:0;height:2px;transition:width var(--Transition-Med) ease;position:absolute;bottom:0;left:0}.skill-badge:hover{border-color:var(--Color-Accent);box-shadow:0 4px 12px var(--Color-Accent-Glow);transform:translateY(-2px)}.skill-badge:hover:after{width:100%}.about-me{background:var(--Color-Section-Alt)}.about-me-wrapper{flex-direction:column;align-items:center;gap:2rem;max-width:1000px;display:flex}.about-me-head{flex-direction:column;align-items:center;gap:1.5rem;display:flex}.about-me-head h3{color:var(--Color-3);max-width:500px;font-size:1.35rem;line-height:1.4}.hero-image2{border-radius:var(--Radius-Md);box-shadow:var(--Shadow-Lg);transition:all var(--Transition-Slow) ease;border:3px solid var(--Color-Accent)}.hero-image2:hover{box-shadow:0 12px 40px var(--Color-Accent-Glow);transform:scale(1.03)rotate(-2deg)}.about-me-content{flex-direction:column;align-items:center;gap:1.5rem;display:flex}.about-me_text{text-align:left;max-width:650px;color:var(--Color-3);opacity:.85;font-size:1rem;line-height:1.8}.about-me_text strong{color:var(--Color-Accent);font-weight:700}.about-stats{flex-wrap:wrap;justify-content:center;gap:1rem;width:100%;margin:1rem 0;display:flex}.stat-item{text-align:center;flex:1;min-width:140px;padding:1.5rem 2rem}.stat-number{color:var(--Color-Accent);font-size:2.5rem;font-weight:700;line-height:1;display:inline}.stat-suffix{color:var(--Color-Accent);font-size:2rem;font-weight:700}.stat-label{opacity:.7;text-align:center;margin-top:.5rem;font-size:.85rem;display:block}.my-work{background:var(--Color-Section-Base)}.my-work-article-wrapper{flex-direction:column;gap:2rem;width:100%;max-width:1200px;margin:2rem 0 3rem;display:flex}.project-card{background:var(--Color-Surface);-webkit-backdrop-filter:blur(12px);border-radius:var(--Radius-Md);box-shadow:var(--Shadow-Sm);transition:all var(--Transition-Slow) ease;border:1px solid var(--Color-Surface-Border);position:relative;overflow:hidden}.project-card:hover{box-shadow:var(--Shadow-Lg);border-color:var(--Color-Accent);transform:translateY(-8px)}.project-overlay{z-index:1;padding:2rem;position:relative}.project-role{text-transform:uppercase;letter-spacing:1.5px;color:var(--Color-Accent);opacity:.9;margin-bottom:.5rem;font-size:.75rem;font-weight:700;display:inline-block}.project-overlay h3{color:var(--Color-3);text-align:left;margin-bottom:.75rem;font-size:1.4rem}.project-overlay p{text-align:left;color:var(--Color-3);opacity:.75;margin-bottom:1rem;font-size:.95rem;line-height:1.6}.tech-stack{flex-wrap:wrap;gap:.5rem;display:flex}.tech-badge{background:var(--Color-Accent);color:#fff;transition:all var(--Transition-Fast) ease;border-radius:50px;padding:.3rem .7rem;font-size:.8rem;font-weight:600;display:inline-block}.tech-badge:hover{background:var(--Color-Accent-Light);transform:scale(1.05)}.project-links{flex-wrap:wrap;gap:.75rem;margin-top:1.25rem;display:flex}.project-link{transition:all var(--Transition-Fast) ease;border-radius:50px;padding:.5rem 1rem;font-size:.85rem;font-weight:600;display:inline-block}.project-link--live{background:var(--Color-3);color:var(--Color-1)}.project-link--live:hover{background:var(--Color-Accent);color:#fff;box-shadow:0 4px 12px var(--Color-Accent-Glow);transform:translateY(-2px)}.project-link--source{border:1px solid var(--Color-3);color:var(--Color-3);background:0 0}.project-link--source:hover{border-color:var(--Color-Accent);color:var(--Color-Accent);transform:translateY(-2px)}.external-icon{vertical-align:text-bottom;flex-shrink:0;width:.95em;height:.95em;margin-left:.3rem}.my-work_articles img{border-radius:0 0 var(--Radius-Md) var(--Radius-Md);width:100%;height:auto;transition:all var(--Transition-Med) ease;opacity:.95;display:block}.my-work_articles a:hover img{opacity:1;transform:scale(1.02)}.my-work_articles img.loaded{animation:.5s fadeIn}.button-cta{text-align:center;border:2px solid var(--Color-3);background:var(--Color-3);min-width:180px;color:var(--Color-1);box-shadow:var(--Shadow-Sm);transition:all var(--Transition-Med) ease;letter-spacing:.5px;cursor:pointer;border-radius:50px;padding:.875rem 2rem;font-size:.95rem;font-weight:600;display:inline-block;position:relative;overflow:hidden}.button-cta--primary{background:var(--Color-Accent);border-color:var(--Color-Accent);color:#fff}.button-cta--primary:hover{background:var(--Color-Accent-Light);border-color:var(--Color-Accent-Light);box-shadow:0 8px 24px var(--Color-Accent-Glow);transform:translateY(-3px)}.button-cta--outline{color:var(--Color-3);background:0 0}.button-cta--outline:hover{background:var(--Color-3);color:var(--Color-1);box-shadow:var(--Shadow-Lg);transform:translateY(-3px)}.button-cta:hover{box-shadow:var(--Shadow-Lg);transform:translateY(-3px)}.button-cta:active{box-shadow:var(--Shadow-Sm);transform:translateY(-1px)}.ripple{pointer-events:none;background:#fff6;border-radius:50%;animation:.6s ease-out ripple-animation;position:absolute;transform:scale(0)}@keyframes ripple-animation{to{opacity:0;transform:scale(4)}}.contact{background:var(--Color-Section-Alt)}.contact-wrapper{flex-direction:column;gap:2.5rem;width:100%;max-width:900px;display:flex}.contact-form{flex-direction:column;gap:1.5rem;padding:2.5rem;display:flex}.form-group{flex-direction:column;gap:.4rem;display:flex}.form-group label{text-transform:uppercase;letter-spacing:1px;opacity:.8;text-align:left;font-size:.85rem;font-weight:700}.form-group input,.form-group textarea{border:1px solid var(--Color-Surface-Border);border-radius:var(--Radius-Sm);background:var(--Color-1);color:var(--Color-3);font-family:var(--Font-B612);transition:all var(--Transition-Med) ease;outline:none;padding:.875rem 1rem;font-size:.95rem}.form-group input:focus,.form-group textarea:focus{border-color:var(--Color-Accent);box-shadow:0 0 0 3px var(--Color-Accent-Glow)}.form-group input::placeholder,.form-group textarea::placeholder{opacity:.4}.form-group textarea{resize:vertical;min-height:120px}.form-error{color:var(--Color-Accent);text-align:left;min-height:1.2em;font-size:.8rem}.form-success{color:#22c55e;text-align:center;padding:1rem;font-weight:600;animation:.4s fadeInUp}.contact-form .button-cta{font-family:var(--Font-B612);align-self:flex-start}.contact-form .button-cta .btn-loading,.contact-form .button-cta.loading .btn-text{display:none}.contact-form .button-cta.loading .btn-loading{display:inline}.contact-info{flex-direction:column;gap:1.5rem;display:flex}.contact-info-item{align-items:flex-start;gap:1rem;display:flex}.contact-info-icon{flex-shrink:0;margin-top:.1rem;font-size:1.5rem}.contact-info-item h3{text-align:left;margin-bottom:.2rem;font-size:.9rem}.contact-info-item p,.contact-info-item a{opacity:.7;text-align:left;transition:color var(--Transition-Fast) ease;font-size:.9rem}.contact-info-item a:hover{color:var(--Color-Accent);opacity:1}.footer{background:var(--Color-3);color:var(--Color-1);padding:0;position:relative;overflow:hidden}.footer:before{content:"";background:linear-gradient(90deg, transparent, var(--Color-Accent), transparent);height:3px;position:absolute;top:0;left:0;right:0}.footer-top{flex-direction:column;gap:2.5rem;width:100%;max-width:1200px;margin:0 auto;padding:3.5rem 2rem 2.5rem;display:flex}.footer-brand .footer-logo{color:var(--Color-1);transition:color var(--Transition-Fast) ease;font-size:1.25rem;font-weight:700}.footer-brand .footer-logo:hover{color:var(--Color-Accent-Light)}.footer-tagline{opacity:.6;text-align:left;margin-top:.5rem;font-size:.9rem}.footer-links h3,.footer-connect h3{text-transform:uppercase;letter-spacing:1.5px;opacity:.5;text-align:left;margin-bottom:1rem;font-size:.85rem}.footer-links ul{flex-direction:column;gap:.5rem;list-style:none;display:flex}.footer-links a{opacity:.7;transition:all var(--Transition-Fast) ease;font-size:.9rem}.footer-links a:hover{opacity:1;color:var(--Color-Accent-Light);padding-left:.5rem}.footer-social_icons{gap:1rem;display:flex}.footer-social_icons a{width:42px;height:42px;transition:all var(--Transition-Med) ease;background:#ffffff14;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;display:flex}.footer-social_icons a:hover{background:var(--Color-Accent);box-shadow:0 4px 16px var(--Color-Accent-Glow);border-color:#0000;transform:translateY(-3px)}.footer-social_icons img{filter:brightness(0)invert();transition:transform var(--Transition-Fast) ease}body.dark-mode .footer-social_icons img{filter:brightness(0)saturate()}.footer-social_icons a:hover img{filter:brightness(0)invert();transform:scale(1.1)}.footer-bottom{text-align:center;border-top:1px solid #ffffff1a;padding:1.5rem 2rem}.footer-copyright{opacity:.5;font-size:.8rem}.back-to-top{background:var(--Color-Accent);color:#fff;cursor:pointer;width:48px;height:48px;box-shadow:0 4px 20px var(--Color-Accent-Glow);z-index:998;opacity:0;visibility:hidden;transition:all var(--Transition-Med) ease;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.3rem;display:flex;position:fixed;bottom:30px;right:30px}.back-to-top.visible{opacity:1;visibility:visible}.back-to-top:hover{background:var(--Color-Accent-Light);box-shadow:0 8px 32px var(--Color-Accent-Glow);transform:translateY(-4px)}.back-to-top:active{transform:translateY(-2px)}figure{justify-content:center;align-items:center;margin:1rem 0;display:flex}a:has(img){transition:opacity var(--Transition-Med) ease;justify-content:center;align-items:center;display:flex}:is(a:has(img):hover,a:has(img):focus-visible){opacity:.85}@media screen and (min-width:600px){.service-article-container{grid-template-columns:repeat(2,1fr);gap:1.5rem;display:grid}.my-work-article-wrapper{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;display:grid}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;display:grid}.about-stats{gap:1.5rem}.contact-wrapper{flex-direction:row;align-items:flex-start;gap:3rem}.contact-form{flex:1.5}.contact-info{flex:1;padding-top:1rem}.footer-top{flex-direction:row;justify-content:space-between;align-items:flex-start}}@media screen and (min-width:900px){.header{padding:.875rem 3rem}.header-dropdown{-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none;background:0 0;border:none;flex-direction:row;justify-content:center;gap:.5rem;position:static;display:flex!important}.header-dropdown li{border:none}.header-dropdown li a{border-radius:8px;padding:.5rem .75rem;font-size:.85rem}.header-dropdown li:hover,.header-dropdown li:focus-within{background:0 0;transform:none}.header-dropdown li:hover a,.header-dropdown li:focus-within a{background:var(--Color-3);color:var(--Color-1);padding-left:.75rem}.header-menu_open{display:none}article.hero-article{flex-direction:row;justify-content:center;align-items:center;gap:5rem;max-width:1200px;display:flex}.hero-text{text-align:left}.hero-text .greeting{font-size:1.1rem}.hero-text .name{font-size:3.5rem}.hero-text .typing-text{font-size:2rem}.tagline{font-size:1.05rem}.hero-cta-group,.hero-socials{justify-content:flex-start}.service-article-container{grid-template-columns:repeat(4,1fr);gap:1.5rem;padding:0;display:grid}.about-me-wrapper{flex-direction:row;justify-content:center;align-items:flex-start;gap:4rem;display:flex}.about-me-head{flex:none;max-width:300px}.about-me-content{flex:1;align-items:flex-start}img.hero-image{width:210px;height:auto}img.hero-image2{width:276px}.my-work-article-wrapper{grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:2rem;display:grid}.section{padding:6rem 4rem}}@media screen and (min-width:1400px){.section{padding:7rem 4rem}article.hero-article{gap:8rem}.hero-text .name{font-size:4rem}img.hero-image{width:240px;height:auto}.service-article-container{gap:2rem}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}html{scroll-behavior:auto}}@media (prefers-contrast:high){.button-cta{border-width:3px}.services-article,.project-card,.skill-category,.form-group input,.form-group textarea{border-width:2px}}
