*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{width:100%;height:100%}body{width:100%;height:100%;overflow-y:scroll;scroll-snap-type:y mandatory;background:#000;background:linear-gradient(to bottom,#000,#5788fe);background-attachment:fixed;font-family:Raleway,sans-serif}#root{width:100%}.hero{position:relative;width:100%;height:100vh;overflow:hidden;cursor:none;scroll-snap-align:start;scroll-snap-stop:always}.landscape{position:absolute;bottom:0;left:0;width:100%;height:100%;background-image:url(/Trees-Landscape-Silhouette.png);background-size:1000px 250px;background-repeat:repeat-x;background-position:center bottom;z-index:1;pointer-events:none}.filter{width:100%;height:100%;position:absolute;top:0;left:0;background:#fe5757;animation:colorChange 30s ease-in-out infinite;animation-fill-mode:both;mix-blend-mode:overlay;z-index:2;pointer-events:none}@keyframes colorChange{0%,to{opacity:0}50%{opacity:.9}}#canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:3}.resume-btn{position:fixed;top:1.5rem;right:2rem;z-index:100;display:flex;align-items:center;gap:.4rem;color:#fffc;text-decoration:none;font-family:Raleway,sans-serif;font-size:.75rem;font-weight:400;letter-spacing:.18em;text-transform:uppercase;border:1px solid rgba(255,255,255,.3);padding:.5rem 1.1rem;border-radius:2px;transition:color .3s ease,border-color .3s ease,box-shadow .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer}.resume-btn:hover{color:#fff;border-color:#ffffffb3;box-shadow:0 0 18px #fff3}.center-content{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2.5rem;z-index:10;pointer-events:none}.center-content>*{pointer-events:auto}.name{font-family:Raleway,sans-serif;font-size:clamp(1.8rem,5vw,4rem);font-weight:200;color:#fff;letter-spacing:.35em;text-transform:uppercase;text-shadow:0 0 40px rgba(255,255,255,.4),0 2px 20px rgba(87,136,254,.5);margin:0;-webkit-user-select:none;user-select:none}.cursor{display:inline-block;margin-left:2px;font-weight:100;animation:blink 1s step-end infinite}.cursor--hidden{animation:none;opacity:0}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.social-links{display:flex;align-items:center;justify-content:center;gap:2.2rem;list-style:none}.social-link{display:flex;align-items:center;gap:.45rem;color:#ffffffa6;text-decoration:none;font-family:Raleway,sans-serif;font-size:.8rem;font-weight:400;letter-spacing:.1em;transition:color .3s ease,filter .3s ease;cursor:pointer}.social-link svg{width:26px;height:26px;flex-shrink:0}.social-link:hover{color:#fff;filter:drop-shadow(0 0 8px rgba(255,255,255,.6))}.social-link--location span{font-size:.75rem;letter-spacing:.12em}@media (max-width: 480px){.resume-btn{top:.75rem;left:.75rem;font-size:.65rem;padding:.35rem .75rem;letter-spacing:.12em;width:fit-content}.name{font-size:clamp(1.4rem,7vw,2rem);letter-spacing:.12em}.social-links{gap:1.4rem}.social-link--location span{display:none}}.skills{padding:5rem 2rem 6rem;text-align:center;height:100vh;scroll-snap-align:start;scroll-snap-stop:always}.skills-title{font-family:Raleway,sans-serif;font-size:clamp(.65rem,1.2vw,.8rem);font-weight:400;letter-spacing:.5em;text-transform:uppercase;color:#ffffff4d;margin-bottom:3rem}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:1rem;max-width:1000px;margin:0 auto}.skill-card{display:flex;flex-direction:column;align-items:center;gap:.65rem;padding:1.25rem .4rem 1rem;border-radius:6px;border:1px solid rgba(255,255,255,.07);background:#ffffff05;transition:border-color .25s ease,background .25s ease,transform .25s ease;cursor:default;-webkit-user-select:none;user-select:none}.skill-card:hover{border-color:#ffffff2e;background:#ffffff0d;transform:translateY(-3px)}.skill-icon{width:46px;height:46px;object-fit:contain;pointer-events:none}.skill-label{font-family:Raleway,sans-serif;font-size:.65rem;font-weight:400;letter-spacing:.04em;color:#ffffff73;text-transform:uppercase;line-height:1.3;text-align:center;word-break:break-word;overflow-wrap:break-word;width:100%}@media (max-width: 600px){.skills{padding:4rem 1rem 5rem}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(76px,1fr));gap:.75rem}.skill-icon{width:38px;height:38px}.skill-label{font-size:.6rem}}.projects{padding:5rem 2rem 6rem;text-align:center;min-height:100vh;scroll-snap-align:start;scroll-snap-stop:always;display:flex;flex-direction:column;align-items:center}.projects-title{font-family:Raleway,sans-serif;font-size:clamp(.65rem,1.2vw,.8rem);font-weight:400;letter-spacing:.5em;text-transform:uppercase;color:#ffffff4d;margin-bottom:3rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;max-width:1100px;width:100%}.project-card{display:flex;flex-direction:column;border-radius:8px;border:1px solid rgba(255,255,255,.07);background:#ffffff05;overflow:hidden;text-align:left;transition:border-color .25s ease,background .25s ease,transform .25s ease}.project-card:hover{border-color:#ffffff29;background:#ffffff0a;transform:translateY(-4px)}.project-preview{width:100%;aspect-ratio:16 / 9;overflow:hidden;background:#ffffff08;border-bottom:1px solid rgba(255,255,255,.07);flex-shrink:0}.project-img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none;transition:transform .4s ease}.project-card:hover .project-img{transform:scale(1.03)}.project-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#5788fe14,#ffffff08)}.project-image-placeholder span{font-family:Raleway,sans-serif;font-size:3rem;font-weight:700;color:#5788fe4d;text-transform:uppercase;letter-spacing:.05em;-webkit-user-select:none;user-select:none}.project-body{display:flex;flex-direction:column;gap:.75rem;padding:1.25rem 1.25rem 1.1rem;flex:1}.project-title{font-family:Raleway,sans-serif;font-size:.95rem;font-weight:600;letter-spacing:.04em;color:#ffffffd9;margin:0}.project-desc{font-family:Raleway,sans-serif;font-size:.75rem;font-weight:400;line-height:1.6;color:#fff6;margin:0}.project-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.1rem}.project-tag{font-family:Raleway,sans-serif;font-size:.6rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:#d0dcf8bf;background:#5788fe14;border:1px solid rgba(87,136,254,.15);border-radius:3px;padding:.2rem .5rem}.project-links{display:flex;gap:.75rem;margin-top:auto;padding-top:.5rem}.project-link{color:#fff;display:inline-flex;align-items:center;gap:.35rem;font-family:Raleway,sans-serif;font-size:.65rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;border:1px solid rgba(255,255,255,.1);border-radius:3px;padding:.3rem .7rem;transition:color .2s ease,border-color .2s ease,background .2s ease}.project-link:hover{border-color:#ffffff40;background:#ffffff0a}.project-link--demo{border-color:#5788fe33}.project-link--demo:hover{color:#5788fe;border-color:#5788fe80;background:#5788fe0f}@media (max-width: 600px){.projects{padding:4rem 1rem 5rem}.projects-grid{grid-template-columns:1fr}}.contact{height:100vh;scroll-snap-align:start;scroll-snap-stop:always;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem}.contact-title{font-family:Raleway,sans-serif;font-size:clamp(.65rem,1.2vw,.8rem);font-weight:400;letter-spacing:.5em;text-transform:uppercase;color:#ffffff4d;margin-bottom:3rem}.contact-form{width:100%;max-width:480px;display:flex;flex-direction:column;gap:1rem}.form-input,.form-textarea{width:100%;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:2px;color:#fffc;font-family:Raleway,sans-serif;font-size:.8rem;font-weight:400;letter-spacing:.05em;padding:.85rem 1rem;outline:none;transition:border-color .25s ease,background .25s ease;resize:none}.form-input::placeholder,.form-textarea::placeholder{color:#ffffff40;letter-spacing:.08em}.form-input:focus,.form-textarea:focus{border-color:#ffffff4d;background:#ffffff0d}.form-submit{align-self:flex-start;background:transparent;border:1px solid rgba(255,255,255,.3);border-radius:2px;color:#ffffffb3;cursor:pointer;font-family:Raleway,sans-serif;font-size:.75rem;font-weight:400;letter-spacing:.18em;padding:.5rem 1.5rem;text-transform:uppercase;transition:color .3s ease,border-color .3s ease,box-shadow .3s ease}.form-submit:hover:not(:disabled){color:#fff;border-color:#ffffffb3;box-shadow:0 0 18px #fff3}.form-submit:disabled{opacity:.5;cursor:not-allowed}.contact-success{font-family:Raleway,sans-serif;font-size:.85rem;font-weight:300;letter-spacing:.1em;color:#ffffff80}.contact-error{font-family:Raleway,sans-serif;font-size:.75rem;letter-spacing:.05em;color:#ff6e6ecc}@media (max-width: 480px){.contact{padding:2rem 1.25rem}}.scroll-dots{position:fixed;right:1.5rem;top:50%;transform:translateY(-50%);z-index:1000;display:flex;flex-direction:column;gap:.75rem;align-items:center}.scroll-dot{width:8px;height:8px;border-radius:50%;border:1px solid rgba(255,255,255,.4);background:transparent;cursor:pointer;padding:0;transition:background .3s ease,transform .3s ease,border-color .3s ease}.scroll-dot:hover{border-color:#fffc;transform:scale(1.25)}.scroll-dot--active{background:#ffffffd9;border-color:#ffffffd9}@media (max-width: 480px){.scroll-dots{right:.75rem}}
