.contact-section{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.contact-content{width:min(90%,1000px);align-items:center;height:50dvh}.contact-content,.glowing-cv-strings{border-left:1px solid var(--deco-line);border-right:1px solid var(--deco-line);display:flex;flex-direction:column}.glowing-cv-strings{height:30dvh;width:max(200px,40%)}.glowing-cv{height:100%;display:flex;flex-direction:column;justify-content:flex-end;position:relative;@media screen and (max-width:680px){font-size:.75rem}}.download-cv-button{border-top:1px solid var(--deco-line);border-bottom:1px solid var(--deco-line);padding:1rem 2rem;display:grid;place-items:center;font-family:var(--font-space-grotesk);font-weight:400;text-transform:uppercase;text-wrap:balance;text-align:center;letter-spacing:.125em;background-color:var(--accent);color:black;position:relative;z-index:2;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:inset 0 1px 0 rgba(255,255,255,.1),inset 0 -1px 0 rgba(0,0,0,.1),0 0 12px var(--accent-tb-s),0 0 24px var(--accent-tb-s),0 0 48px var(--accent-tb-l),0 2px 8px rgba(0,0,0,.15),0 4px 16px var(--accent-tb-s);animation:gentlePulse 3s ease-in-out infinite alternate;&:before{top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(45deg,var(--accent),var(--accent-tb-l),var(--accent));border-radius:inherit;z-index:-1;opacity:0;transition:opacity .3s ease;filter:blur(4px)}&:after,&:before{content:"";position:absolute}&:after{top:50%;left:50%;width:0;height:0;background:radial-gradient(circle,rgba(255,255,255,.8) 0,rgba(255,255,255,.4) 40%,transparent 70%);border-radius:50%;transform:translate(-50%,-50%);transition:all .6s cubic-bezier(.4,0,.2,1);z-index:1}&:hover{cursor:pointer;transform:translateY(-1px) scale(1.01);box-shadow:inset 0 1px 0 rgba(255,255,255,.15),inset 0 -1px 0 rgba(0,0,0,.1),0 0 16px var(--accent-tb-l),0 0 32px var(--accent-tb-s),0 0 64px var(--accent-tb-s),0 3px 12px rgba(0,0,0,.2),0 6px 20px var(--accent-tb-s);&:before{opacity:1;animation:rotateBorder 3s linear infinite}&:after{width:100%;height:100%;opacity:.3}}&:active{transform:translateY(-1px) scale(1.01);transition:transform .1s ease}}@keyframes gentlePulse{0%{box-shadow:inset 0 1px 0 rgba(255,255,255,.1),inset 0 -1px 0 rgba(0,0,0,.1),0 0 12px var(--accent-tb-s),0 0 24px var(--accent-tb-s),0 0 48px var(--accent-tb-l),0 2px 8px rgba(0,0,0,.15),0 4px 16px var(--accent-tb-s)}to{box-shadow:inset 0 1px 0 rgba(255,255,255,.1),inset 0 -1px 0 rgba(0,0,0,.1),0 0 16px var(--accent-tb-l),0 0 28px var(--accent-tb-s),0 0 56px var(--accent-tb-l),0 2px 8px rgba(0,0,0,.15),0 4px 16px var(--accent-tb-s)}}@keyframes rotateBorder{0%{background:linear-gradient(0deg,var(--accent),var(--accent-tb-l),var(--accent))}25%{background:linear-gradient(90deg,var(--accent),var(--accent-tb-l),var(--accent))}50%{background:linear-gradient(180deg,var(--accent),var(--accent-tb-l),var(--accent))}75%{background:linear-gradient(270deg,var(--accent),var(--accent-tb-l),var(--accent))}to{background:linear-gradient(1turn,var(--accent),var(--accent-tb-l),var(--accent))}}.glowing-cv{&:before{content:"";position:absolute;top:50%;left:50%;width:150%;height:150%;background:radial-gradient(circle,var(--accent-tb-s) 0,transparent 60%);transform:translate(-50%,-50%);z-index:0;pointer-events:none;animation:subtleAmbient 5s ease-in-out infinite alternate}}@keyframes subtleAmbient{0%{opacity:.2;transform:translate(-50%,-50%) scale(1)}to{opacity:.4;transform:translate(-50%,-50%) scale(1.05)}}.hero-section{width:100%;height:100%;border-bottom:1px solid var(--deco-line);animation:upToDown 1s ease-out 0s 1 normal forwards}.hero-content,.hero-section{display:flex;align-items:center;justify-content:center}.hero-content{width:min(90%,1000px);border-left:1px solid var(--deco-line);border-right:1px solid var(--deco-line);flex-direction:column;padding:2rem 0;gap:1rem}.hero-image-container{width:min(60%,16rem);aspect-ratio:5/6;position:relative}.hero-image{object-fit:cover;z-index:0;position:absolute;inset:0}.image-overlay{position:absolute;inset:0;background:linear-gradient(rgba(0,0,0,.15),rgba(0,0,0,.15));z-index:1;pointer-events:none}.tape{position:absolute;background-color:rgba(255,255,255,.5);z-index:2;width:1.5rem}.tape-top-left{top:-.5rem;left:0;transform:rotate(25deg);height:3.5rem}.tape-top-right{top:-.5rem;right:0;transform:rotate(-32deg);height:4rem}.tape-bottom-left{bottom:-1rem;left:0;transform:rotate(-45deg);height:4.5rem}.tape-bottom-right{bottom:-1rem;right:0;transform:rotate(32deg);height:3.5rem}.hero-titles{width:min(600px,90%);display:flex;flex-direction:column;gap:.5rem}.hero-subtitle,.hero-title{text-align:center}.hero-subtitle{text-wrap:balance}@keyframes upToDown{0%{transform:translatey(-100%);opacity:0}to{transform:translatey(0);opacity:1}}.project-intro{display:grid;grid-template-columns:repeat(3,1fr);height:15rem;border-bottom:1px solid var(--deco-line);@media screen and (max-width:800px){grid-template-columns:repeat(2,1fr)}@media screen and (max-width:580px){grid-template-columns:1fr;height:auto}}.project-intro-icon{display:grid;place-items:center;width:3rem;aspect-ratio:1/1;background-color:var(--primary);border-radius:50%;margin-bottom:1rem}.project-intro-middle,.project-intro-text{border-right:1px solid var(--deco-line);padding:2rem}.project-intro-text{border-right:1px solid var(--deco-line);font-weight:500;display:flex;flex-direction:column;text-wrap:balance;justify-content:space-between}.project-intro-titles{display:inherit;flex-direction:inherit;gap:.5rem}.project-intro-middle{@media screen and (max-width:800px){display:none}}.project-intro-last{padding:2rem;display:flex;align-items:flex-end;justify-content:flex-end;color:var(--text-light);font-size:1rem}.project-intro-link{display:inline-flex;align-items:flex-end;text-wrap:balance;transition:color .25s ease;gap:1.25rem;&:hover{color:var(--text)}}.link-icon{transition:transform .25s ease}.project-intro-link:hover .link-icon{transform:scale(1.5)}.tarpit-intro{display:grid;grid-template-columns:repeat(3,1fr);min-height:18rem;@media screen and (max-width:800px){grid-template-columns:1fr;grid-template-rows:1fr 2fr}}.tarpit-intro-text{padding:2rem;border-right:1px solid var(--deco-line);display:flex;flex-direction:column;justify-content:space-around;gap:2rem;@media screen and (max-width:800px){border-left-color:currentcolor;border-left-style:none;border-left-width:medium;border-bottom-color:currentcolor;border-bottom-style:none;border-bottom-width:medium;border-right-color:currentcolor;border-right-style:none;border-right-width:medium;border-top-color:currentcolor;border-top-style:none;border-top-width:medium}}.tarpit-what{display:flex;flex-direction:column;& h3{text-transform:uppercase}& p{color:var(--text-light);font-size:.925rem;text-wrap:balance}}.tarpit-tech{display:flex;flex-wrap:wrap;gap:.5rem;font-family:var(--font-space-grotesk);font-weight:100;font-size:.625rem;text-transform:uppercase;letter-spacing:.25em}.tarpit-tech-item{border:1px solid var(--deco-line);padding:.25rem .5rem;background-color:var(--primary);&:hover{transform:scale(1.5);background-color:black;border-color:var(--accent-tb-l);cursor:default}}.tarpit-images{display:grid;grid-column:2/4;@media screen and (max-width:800px){grid-row:2/3;grid-column:1/-1}}.tarpit-image-container{border:1px solid var(--deco-line);border-radius:.25rem;background-color:rgba(0,0,0,.25);-webkit-backdrop-filter:blur(.5rem);backdrop-filter:blur(.5rem);margin:.5rem;display:flex;align-items:flex-end;justify-content:center;transition:all .3s ease-in;&:hover{cursor:pointer;margin:.125rem}}.project-image{position:relative;height:90%;width:90%;border-radius:.25rem;transition:all .3s ease-in;@media screen and (max-width:580px){display:flex;justify-content:center;height:80%;width:80%;max-width:220px}}.tarpit-image-container:hover .project-image{width:100%;height:100%}.project-pic{object-fit:fill;border-radius:.25rem;@media screen and (max-width:580px){aspect-ratio:1/1}}.projects{width:100%;height:100%;align-items:center;justify-content:center;animation:downToUp 1s ease-out 0s 1 normal forwards}.projects,.projects-content{display:flex;flex-direction:column}.projects-content{width:min(90%,1000px);border-left:1px solid var(--deco-line);border-right:1px solid var(--deco-line)}.projects-divider{border-bottom:1px solid var(--deco-line)}.projects-divider,.projects-divider-last{height:2rem;border-top:1px solid var(--deco-line);width:100%}.projects-divider-last{border-bottom:none}@keyframes downToUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}