@import"https://fonts.googleapis.com/css2?family=Raleway:wght@400;700&display=swap";.nav{display:flex;align-items:center;height:10vh;width:90%;max-width:1536px;margin:0 auto;font-weight:700;z-index:2}.nav .space-between{width:100%;display:flex;justify-content:space-between;align-items:center}.nav .logo{color:var(--white);cursor:pointer;font-size:1.2rem;text-decoration:none;-webkit-user-select:none;user-select:none;flex-shrink:0}.nav .nav-list{margin:0;padding:0;list-style-type:none;display:flex;justify-content:center;align-items:center;gap:.5rem}.nav .nav-list li{display:flex;justify-content:center;align-items:center}.nav .nav-list li a{display:flex;justify-content:center;align-items:center;gap:.4rem;color:var(--white);text-decoration:none;font-weight:700;font-size:.8rem;text-underline-offset:.25rem;transition:color .2s}.nav .nav-list li a:hover,.nav .nav-list li a:focus{text-decoration:underline}.nav .nav-list li a svg{width:1.4rem;height:1.4rem;flex-shrink:0}@media(max-width:420px){.nav .nav-list{gap:.8rem}.nav .nav-list li a{font-size:0;gap:0}}@media(min-width:768px){.nav{width:75%}.nav .logo{font-size:1.4rem}.nav .nav-list{gap:1rem}.nav .nav-list li{padding:0 16px}.nav .nav-list li:last-child{padding:0 0 0 16px}.nav .nav-list li a{font-size:1rem}.nav .nav-list li a svg{font-size:1.75rem;width:auto;height:auto}}.hero{position:relative;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;width:90%;max-width:1536px;margin:3rem auto}.hero .cta{width:100%;display:flex;justify-content:space-between;align-items:flex-start;flex-direction:column-reverse;gap:2.5rem;margin-bottom:1.25rem}.hero .title{font-size:2.2rem;font-weight:700}.hero .portrait-container{width:100%;max-width:150px}.hero .portrait{position:relative;width:100%;object-fit:contain;height:100%;border-radius:2rem;box-shadow:1rem 1rem #fff;filter:grayscale(100%) contrast(110%);clip-path:circle(100%);transition:box-shadow .3s ease,clip-path .3s ease,filter .3s ease}@media(prefers-reduced-motion:no-preference){.hero .portrait-container:hover .portrait{box-shadow:0 0 #fff;clip-path:circle(50%);filter:none;animation:bounceImage .6s cubic-bezier(.33,1,.68,1) infinite alternate}}.hero .job-title{font-size:.9rem;font-weight:400;line-height:1.5}@keyframes bounceImage{0%{transform:translateY(0) rotateX(20deg)}to{transform:translateY(-30px) rotateX(0)}}@media(min-width:768px){.hero{width:75%;margin:8rem auto}.hero .cta{flex-direction:row;align-items:center;gap:4rem}.hero .title{font-size:4rem}.hero .portrait-container{max-width:200px}.hero .portrait{box-shadow:1.5rem 1.5rem #fff}.hero .job-title{font-size:1.2rem}}@media(min-width:1280px){.hero .title{font-size:6rem;margin-right:2rem}.hero .portrait-container{max-width:300px}}@media(min-width:1536px){.hero .title{font-size:7.5rem;margin-right:3rem}.hero .portrait-container{max-width:400px}.hero .job-title{font-size:1.4rem}}.about-container{position:relative;width:90%;margin:5rem auto;max-width:1536px;z-index:10}.about-container h2{font-size:1.8rem;font-weight:700;margin-bottom:1.5rem}.about-container p{font-size:1rem;line-height:1.8;max-width:65ch}.about-container p+p{margin-top:1rem}@media(min-width:768px){.about-container{width:75%;margin:8rem auto}.about-container h2{font-size:3rem;margin-bottom:3rem}.about-container p{font-size:1.2rem}}.skills-section{width:90%;max-width:1200px;margin:4rem auto;z-index:10;position:relative}.category-group{margin-bottom:3.5rem}.category-label{font-size:.9rem;text-transform:uppercase;letter-spacing:.15rem;color:#888;margin-bottom:1.5rem;font-weight:700;border-bottom:1px solid #333;padding-bottom:.5rem;display:inline-block}.skills-flex-container{display:flex;flex-wrap:wrap;gap:1rem}.modern-skill-card{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100px;height:100px;background:#1a1a1a;border:1px solid #333;border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:help}.modern-skill-card:hover{background:#222;border-color:#fff;transform:translateY(-5px)}.icon-box{width:40px!important;height:40px!important;display:flex;align-items:center;justify-content:center;margin-bottom:8px}.icon-box svg{width:100%!important;height:100%!important;display:block!important;fill:currentColor}.skill-name{font-size:.7rem;font-weight:700;color:#ccc;text-align:center}.modern-skill-card:after{content:attr(data-tooltip);position:absolute;bottom:110%;left:50%;transform:translate(-50%,10px);background:#fff;color:#000;padding:6px 10px;border-radius:6px;font-size:.7rem;width:150px;text-align:center;opacity:0;visibility:hidden;transition:.2s ease;pointer-events:none;box-shadow:0 5px 15px #00000080;z-index:100}.modern-skill-card:hover:after{opacity:1;visibility:visible;transform:translate(-50%)}@media(min-width:768px){.skills-section{width:75%}.modern-skill-card{width:120px;height:120px}.icon-box{width:50px!important;height:50px!important}.skill-name{font-size:.8rem}}.projects-grid-section{width:90%;max-width:1400px;margin:6rem auto}.main-section-title{font-size:2.5rem;font-weight:900;margin-bottom:4rem;text-align:left}.project-group-container{margin-bottom:5rem}.group-title{font-size:1rem;text-transform:uppercase;letter-spacing:2px;color:#fff6;margin-bottom:2rem;border-left:3px solid #fff;padding-left:1rem}.modern-projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}.new-project-card{background:#161616;border:1px solid #282828;border-radius:16px;overflow:hidden;transition:all .3s ease;display:flex;flex-direction:column}.new-project-card:hover{border-color:#555;transform:translateY(-8px)}.project-image-wrapper{position:relative;height:180px;background:#000}.project-image-wrapper img{width:100%;height:100%;object-fit:cover;opacity:.8}.project-overlay{position:absolute;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;gap:.8rem;opacity:0;transition:.3s ease}.project-image-wrapper:hover .project-overlay{opacity:1}.project-overlay a{padding:.5rem 1rem;background:#fff;color:#000;border-radius:6px;font-weight:700;font-size:.75rem;text-decoration:none}.project-details{padding:1.5rem;flex-grow:1;display:flex;flex-direction:column}.project-meta-header{margin-bottom:.75rem}.type-pill{font-size:.6rem;color:#888;text-transform:uppercase;font-weight:800}.project-name-heading{font-size:1.3rem;font-weight:800;margin-bottom:.5rem;color:#fff}.project-desc-text{font-size:.85rem;color:#aaa;line-height:1.5;margin-bottom:1.5rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.project-tags-container{margin-top:auto;display:flex;flex-wrap:wrap;gap:.5rem}.skill-tag{background:#252525;color:#eee;font-size:.65rem;font-weight:700;padding:4px 10px;border-radius:4px;border:1px solid #333}@media(max-width:768px){.modern-projects-grid{grid-template-columns:1fr}.main-section-title{font-size:2rem}}footer{height:100vh!important;min-height:100vh!important;width:100%;display:grid!important;place-content:center!important;place-items:center!important;background:var(--black);text-align:center;position:relative;overflow:hidden;padding-bottom:15vh!important;margin:0!important}footer h2{color:var(--white);font-size:3rem;font-weight:800;margin:0 0 3rem;line-height:1}.footer-links{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:1.5rem;margin:0;padding:0;list-style-type:none;width:100%}.footer-links li a{display:flex;align-items:center;gap:.5rem;color:var(--white);text-decoration:none;font-weight:700;font-size:1.1rem;transition:all .3s ease}.footer-links li a:hover{text-decoration:underline;opacity:.8;transform:translateY(-3px)}@media(min-width:768px){footer h2{font-size:6rem;margin-bottom:4rem}.footer-links{gap:4rem}.footer-links li a{font-size:1.5rem}}.intro-overlay{background:var(--white);position:fixed;min-height:100vh;min-height:100dvh;width:100%;z-index:3;display:flex;justify-content:center;align-items:center}.intro-overlay .ball{position:absolute;top:-50vh;left:50%;transform:translate(-50%);border-radius:50%;width:50px;height:50px;background:var(--black)}html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font:inherit;vertical-align:baseline}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}body{line-height:1}ol,ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:"";content:none}table{border-collapse:collapse;border-spacing:0}*,*:before,*:after{box-sizing:border-box}*{margin:0}body{-webkit-font-smoothing:antialiased}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}#root,#__next{isolation:isolate}:root{--black: #121212;--white: #fff;--font: "Raleway", sans-serif}body,html{padding:0;margin:0;box-sizing:border-box;background:var(--black);color:var(--white);font-family:var(--font);overflow-x:hidden;width:100%}*::selection{color:#000;background-color:#fff}.hidden-text{clip:rect(1px,1px,1px,1px);height:1px;overflow:hidden;position:absolute;white-space:nowrap;width:1px}.hidden-text:focus{clip:auto;height:auto;overflow:auto;position:absolute;width:auto}.playful{transition:all .4s cubic-bezier(.15,.75,.45,.95) 0s;animation:10s ease 0s infinite alternate none running rainbow}.playful-hover{transition:all .4s cubic-bezier(.15,.75,.45,.95) 0s}.playful-hover:hover,.playful-hover:focus{animation:10s ease 0s infinite alternate none running rainbow}@keyframes rainbow{0%{color:#f04dff}25%{color:#ff4d4d}50%{color:#ffc54d}75%{color:#6aed76}to{color:#09f}}@media(min-width:768px){.footer-spacer{height:6rem}}
