@import"https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,200..800&family=Unbounded:wght@200..900&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,100..1000;1,9..40,100..1000&display=swap";@import"https://fonts.googleapis.com/css2?family=Zalando+Sans+Expanded:ital,wght@0,200..900;1,200..900&display=swap";@import"https://fonts.googleapis.com/css2?family=Space+Mono:ital,wght@0,400;0,700;1,400;1,700&display=swap";@import"https://fonts.googleapis.com/css2?family=Syne:wght@400..800&display=swap";@import"https://fonts.googleapis.com/css2?family=Asset&family=Syne:wght@400..800&display=swap";@import"https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&display=swap";@import"https://fonts.googleapis.com/css2?family=Walter+Turncoat&display=swap";@import"https://fonts.googleapis.com/css2?family=Indie+Flower&display=swap";@import"https://fonts.googleapis.com/css2?family=Borel&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}html{font-size:16px}@media(max-width:375px){html{font-size:11px}}@media(min-width:376px)and (max-width:430px){html{font-size:12px}}@media(min-width:431px)and (max-width:768px){html{font-size:13px}}@media(min-width:769px)and (max-width:1024px){html{font-size:14px}}@media(min-width:1025px)and (max-width:1279px){html{font-size:14.4px}}@media(min-width:1280px)and (max-width:1599px){html{font-size:15px}}@media(min-width:1600px)and (max-width:1919px){html{font-size:15.5px}}@media(min-width:1920px)and (max-width:2559px){html{font-size:16px}}@media(min-width:2560px){html{font-size:21.6px}}@keyframes blink{0%,49%{opacity:1}50%,to{opacity:0}}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0;padding:0;scroll-behavior:smooth;scroll-snap-type:y mandatory;overflow-y:scroll}body{font-family:Arial,sans-serif;color:#000;cursor:none;background-image:url(/images/background.svg);background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed;position:relative}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");opacity:.13;pointer-events:none;z-index:1}#root>*{position:relative;z-index:2}a,button,input,textarea{cursor:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;position:relative;z-index:2}button:focus{outline:none}input,textarea,[contenteditable]{cursor:text!important}.custom-cursor{width:1.5rem;height:1.5rem;background:#ffe57299;border-radius:50%;position:fixed;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .3s ease,height .3s ease,background .3s ease,border-radius .3s ease;display:flex;align-items:center;justify-content:center;color:#fff;font-size:0;font-weight:700}.custom-cursor.on-project{width:8rem;height:8rem;font-size:7.5rem;color:#84cdbd;background:#ffe57299}.custom-cursor.on-clickable{width:2.75rem;height:2.75rem;background:#ffe57299}.custom-cursor.on-text{width:1.5rem;height:1.5rem;background:#ffe57299}.custom-cursor.on-input{width:2px;height:1.5rem;border-radius:0;background:#000;animation:blink 1s infinite}body.project-page .custom-cursor{display:none}h1{font-size:10rem}::selection{background-color:#ffe57299;color:#000}::-moz-selection{background-color:#ffe57299;color:#000}.top-left-buttons{position:absolute;top:50%;right:1rem;display:flex;gap:.9375rem;align-items:center;flex-direction:column}.trad-button{display:flex;padding:.625rem;border-radius:.625rem;font-size:1.7rem;color:#000;background:none;border:none;font-family:Zalando Sans Expanded,sans-serif;font-weight:800;font-style:normal;transition:color .2s ease}.trad-button:hover{color:#79baac;transform:scale(1.1)}.navbar{display:flex;flex-direction:row;position:fixed;top:.9375rem;left:5rem;right:5rem;justify-content:center;gap:clamp(1.5rem,5vw,7rem);padding:.625rem 1.5rem;border-radius:.625rem;z-index:1000;font-size:1.4rem;font-family:Syne,sans-serif;font-weight:700}.navbar button{color:#54b2ca92;background:none;border:none;font-size:clamp(1.2rem,1.5vw,1.7rem);cursor:pointer;padding:0;font-family:inherit;font-weight:700;transition:color .2s ease;position:relative;z-index:1;white-space:nowrap}.navbar button:hover{color:#387787b3}.navbar button:focus{outline:none}.navbar button.active{color:#387787b3}.navbar button:after{content:"";position:absolute;bottom:0;left:0;width:0%;height:100%;background-color:#ffe5729b;z-index:-1;transition:width .8s ease}.navbar button.active:after{width:100%}.navbar button:not(.active):after{transition:width .2s ease}.home-container{display:flex;position:relative;flex-direction:column;justify-content:center;align-items:center;padding-top:4.375rem;scroll-snap-align:start;scroll-snap-stop:normal;height:100vh;transition:background-color .3s ease,color .3s ease}.home-container h1{color:#000;margin:0;margin-bottom:1rem;line-height:.9;transition:color .3s ease;font-family:Zalando Sans Expanded,sans-serif;font-weight:800;font-size:clamp(3.8rem,4.8vw,5.5rem)}.home-container .subtitle{color:#000;margin:0;font-size:clamp(1.4rem,1.6vw,1.9rem);font-weight:400;line-height:1.1;transition:color .3s ease;font-family:Unbounded,sans-serif;font-optical-sizing:auto}.home-container .subtitle-star{color:#ffeb91;font-size:2rem;font-weight:400;line-height:1.1;font-family:Unbounded,sans-serif}.scroll-indicator{position:absolute;bottom:2.5rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;animation:revealFade .6s ease 1.2s both;opacity:0;transition:opacity .4s ease}.home-container.active-section .scroll-indicator{opacity:1}.scroll-indicator span{font-family:Zalando Sans Expanded,sans-serif;font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:#000;opacity:.5}.scroll-arrow{width:1.5rem;height:1.5rem;border-right:2px solid black;border-bottom:2px solid black;transform:rotate(45deg);opacity:.65}.about-me-container{display:flex;justify-content:center;align-items:center;height:100vh;scroll-snap-align:start;scroll-snap-stop:normal}.about-content{display:flex;flex-direction:row;justify-content:space-between;gap:2rem;width:100%;padding:0 2.5rem;height:100%}.about-title{font-family:Zalando Sans Expanded,sans-serif;font-size:2.8rem;font-weight:800;color:#000;margin:0 0 1.5rem;text-align:left;background:linear-gradient(#ffe5729b,#ffe5729b);background-size:100% 55%;background-position:0 50%;background-repeat:no-repeat;width:fit-content;display:inline-block}.about-text-left{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:0 clamp(2.5rem,3.5vw,4rem);font-family:DM Sans,sans-serif;font-weight:400;font-size:clamp(1.15rem,1.2vw,1.35rem);line-height:1.6;text-align:left}.cv-download-text{background:linear-gradient(#ffe5729b,#ffe5729b);background-size:100% 75%;background-position:0 50%;background-repeat:no-repeat;cursor:none}.about-photo-wrapper{display:flex;justify-content:center;align-self:flex-end;padding-right:clamp(2rem,3.5vw,4rem);background:none;border:none;padding-bottom:0;cursor:none}.about-me-container .profile-photo{width:clamp(30rem,38vw,47rem);height:clamp(34rem,44vw,53rem);object-fit:cover}.skills-container{position:relative;display:flex;justify-content:center;align-items:center;height:100vh;scroll-snap-align:start;overflow:hidden}.skills-title-wrapper{position:relative;z-index:10;display:flex;align-items:center;justify-content:center;gap:1rem}.skills-title{font-size:3rem;font-family:Zalando Sans Expanded,sans-serif;font-weight:600;text-align:center;max-width:600px;line-height:1.2;margin:0}.skills-info-button{width:2.5rem;height:2.5rem;min-width:2.5rem;min-height:2.5rem;border-radius:50%;border:4px solid black;background:transparent;color:#000;font-size:1.5rem;font-weight:700;cursor:none;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);font-family:Zalando Sans Expanded,sans-serif;font-weight:800;flex-shrink:0;padding:0;outline:none}.skills-info-button:hover{transform:scale(1.15) rotate(15deg);background:#fae89acc;border-color:#000c;animation:wiggle .5s ease-in-out}.skills-info-button:focus{outline:none}.skills-info-button:active{transform:scale(.95);outline:none}@keyframes wiggle{0%,to{transform:scale(1.15) rotate(15deg)}25%{transform:scale(1.15) rotate(10deg)}50%{transform:scale(1.15) rotate(20deg)}75%{transform:scale(1.15) rotate(12deg)}}.skills-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:1000;cursor:none}.skills-modal{position:relative;background:#ecdfa7fa;padding:3rem 4rem;border-radius:1rem;max-width:500px;cursor:none}.skills-modal-close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;font-size:1.5rem;color:#000;cursor:none;transition:transform .2s ease;padding:.25rem;line-height:1}.skills-modal-close:hover{transform:scale(1.2)}.skills-modal-content{font-family:DM Sans,sans-serif;color:#000}.skills-modal-title{font-family:Zalando Sans Expanded,sans-serif;font-size:2rem;font-weight:700;text-align:center;margin:0 0 2rem;color:#000}.skills-modal-section{margin-bottom:1.5rem}.skills-modal-section:last-child{margin-bottom:0}.skills-modal-category{font-family:Zalando Sans,sans-serif;font-size:1.1rem;font-weight:600;margin:0 0 .25rem;color:#353535e4;text-align:left}.skills-modal-list{font-family:DM Sans,sans-serif;font-size:1.05rem;font-weight:400;margin:0;color:#000;text-align:left;line-height:1.6}.skills-organic{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.skill-logo{pointer-events:all;transition:transform .1s ease-out;will-change:transform;-webkit-user-select:none;user-select:none}.skill-logo img{width:clamp(23rem,31vw,38rem);height:clamp(23rem,31vw,38rem);opacity:.6;object-fit:contain;transition:filter .3s ease;filter:grayscale(0%) opacity(1) drop-shadow(0 4px 12px rgba(0,0,0,.2))}.projects-container{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:0;padding-top:3.75rem;scroll-snap-align:start;scroll-snap-stop:normal;height:100vh;transition:background-color .2s ease,color .2s ease}.projects-container h1{color:#000;margin:0;line-height:.9;transition:color .3s ease;font-family:Bricolage Grotesque,sans-serif}.projects-image-container{display:flex;justify-content:center;align-items:center;width:100%;gap:clamp(1rem,2.5vw,3.5rem);padding:0 2rem}.projects-photo{width:clamp(24rem,30vw,37rem);height:clamp(32.5rem,40vw,50rem);border-radius:clamp(2.2rem,2.8vw,3.5rem);object-fit:cover;object-position:center;display:block}.project-button{border:none;background:none;padding:0;cursor:none}.project-button img{display:block}.project-item{display:flex;flex-direction:column;align-items:center;gap:.2rem}.project-label{font-family:Syne,serif;font-weight:400;font-style:normal;font-size:1.4rem;color:#353535e4;margin:0;text-align:center}.contact-wrapper{scroll-snap-align:start;scroll-snap-stop:normal;height:100vh;display:flex;flex-direction:column;overflow:hidden}.contact-container{display:flex;flex-direction:column;justify-content:space-between;align-items:stretch;padding:4.5rem 0 0;flex:1;transition:background-color .2s ease,color .2s ease;position:relative;z-index:1}.contact-container:after{content:"";position:absolute;bottom:-4px;left:0;right:0;height:4px;background:inherit;background-image:url(/images/background.svg);background-size:cover;background-position:center;background-attachment:fixed;z-index:2}.contact-content{display:flex;flex-direction:row;justify-content:space-between;align-items:center;margin:auto 0;padding:0}.contact-left{width:40%;flex-shrink:0;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:clamp(3rem,5vw,7.5rem) clamp(1.5rem,3.5vw,5rem) clamp(3rem,5vw,7.5rem) clamp(3.5rem,5.5vw,8rem);position:relative}.contact-left .title-text{color:#000;font-family:Zalando Sans Expanded,sans-serif;font-size:1.4rem;font-weight:700;padding-bottom:.7rem;z-index:1}.contact-left .text{color:#000;font-family:DM Sans,sans-serif;font-weight:400;font-size:1.2rem;z-index:1}.text-highlight{background:linear-gradient(#ffe5729b,#ffe5729b);background-size:100% 65%;background-position:0 62%;background-repeat:no-repeat;font-weight:600}.contact-footer{display:flex;justify-content:center;align-items:center;gap:clamp(3rem,14vw,22rem);width:100%;padding:3rem 2rem .9375rem;border-top:none;font-family:Zalando Sans Expanded,sans-serif;font-weight:800;font-size:clamp(1.1rem,1.1vw,1.6rem);flex-shrink:0}.contact-footer a{font-weight:800;color:#000;text-decoration:none;position:relative;transition:transform .3s ease;padding-left:1rem}.contact-footer a:before{content:">";position:absolute;left:0;opacity:1;transition:opacity .3s ease}.contact-footer a:hover:before{opacity:0}.contact-footer a:after{content:"";position:absolute;bottom:0;left:1rem;right:0;height:2px;background:#000;transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.contact-footer a:hover:after{transform:scaleX(1);transform-origin:left}.contact-footer a:not(:hover):after{transform:scaleX(0);transform-origin:right}.site-footer{display:flex;justify-content:space-between;align-items:center;width:100%;padding:1.5rem 2rem .9375rem;background:#ffeb91;scroll-snap-align:start;scroll-snap-stop:normal}.site-footer-visit,.site-footer-copyright{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:600;color:#00000080;margin:0}.contact-form-wrapper{display:flex;flex-direction:column;width:60%;flex-shrink:0;justify-content:center}.contact-form{display:flex;flex-direction:column;justify-content:center;gap:1.5625rem;width:100%;padding-right:clamp(2rem,5vw,7.5rem);position:relative}.form-label{font-family:Zalando Sans Expanded,sans-serif;font-size:2rem;font-weight:800;color:#000;margin:0;padding:1.875rem 5.625rem 1.25rem 0px;text-align:left;background:linear-gradient(#ffe5729b,#ffe5729b);background-size:0% 45%;background-position:0 62%;background-repeat:no-repeat;width:fit-content;display:inline-block;padding-right:0;transition:background-size 1.5s cubic-bezier(.16,1,.3,1) .3s}.contact-wrapper.active-section .form-label{background-size:100% 45%}.form-group{display:flex;flex-direction:column;gap:.5rem;width:100%}.form-group input,.form-group textarea{font-family:Space Mono,monospace;font-weight:400;font-size:1.5rem;padding:.75rem 1rem;border:2px solid rgba(255,229,114,.4);border-radius:.625rem;background:#ffe57240;transition:all .3s ease;outline:none;color:#66a09e}.form-group input:focus,.form-group textarea:focus{border-color:#7fb6b4;box-shadow:0 0 0 3px #6ba2a04d}.form-group textarea{resize:vertical;min-height:11.25rem}.submit-button{font-family:Zalando Sans Expanded,sans-serif;font-size:1rem;font-weight:600;padding:.9375rem 2.5rem;border:none;border-radius:.625rem;background:#ffe5729b;color:#000;transition:all .3s ease;align-self:flex-end;display:flex;align-items:center;justify-content:center;gap:.625rem;margin-top:-1rem}.submit-button:hover{background:#ffeb91}button[type=submit]:focus-visible{outline:none;border-color:#7fb6b4;box-shadow:0 0 0 3px #6ba2a04d}.submit-button:hover:not(:disabled){background:#ffeb91}.submit-button:focus-visible{outline:none;border-color:#7fb6b4;box-shadow:0 0 0 3px #6ba2a04d}.submit-button:disabled{opacity:.6;cursor:not-allowed}.submit-button:active:not(:disabled){transform:scale(.98)}.turnstile-info{font-family:DM Sans,sans-serif;font-size:.7rem;font-weight:400;color:#0006;margin:.1rem 0 0}.spinner{width:1rem;height:1rem;border:2px solid rgba(0,0,0,.2);border-top-color:#000;border-radius:50%;animation:spin .8s linear infinite;display:inline-block}.success-overlay{position:absolute;top:0;left:0;right:clamp(2rem,5vw,8.4375rem);bottom:3.75rem;background:transparent;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1.25rem;z-index:10;animation:fadeIn .3s ease-out;pointer-events:none}.success-checkmark{width:11.25rem;height:11.25rem;animation:scaleIn .5s ease-out}.checkmark-svg{width:100%;height:100%;border-radius:50%;display:block;stroke-width:2;stroke:#98ba74;stroke-miterlimit:10}.checkmark-circle{stroke-dasharray:166;stroke-dashoffset:166;stroke-width:2;stroke:#98ba74;fill:none;animation:stroke .6s cubic-bezier(.65,0,.45,1) forwards}.checkmark-check{transform-origin:50% 50%;stroke-dasharray:48;stroke-dashoffset:48;stroke:#98ba74;stroke-width:3;animation:stroke .3s cubic-bezier(.65,0,.45,1) .4s forwards}@keyframes fadeInText{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(0);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}@keyframes stroke{to{stroke-dashoffset:0}}.rotating-badge{position:absolute;top:1.4rem;left:clamp(2.8rem,4.8vw,7.6rem);width:clamp(16rem,22vw,31.875rem);height:clamp(5rem,6.5vw,9.375rem);display:flex;align-items:center;justify-content:center;z-index:0;opacity:1;transform:translate(-50%)}.badge-svg{width:100%;height:100%;animation:rotate 20s linear infinite}.rotating-text{fill:#ffeb91;font-size:2.4rem;font-weight:800;letter-spacing:.05rem;text-transform:uppercase;font-family:Space Grotesk,sans-serif}.badge-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:2.8rem;height:2.8rem;background:var(--bg-color);border-radius:50%;display:flex;align-items:center;justify-content:center}.badge-icon{font-size:2.5rem;color:#ffeb91}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.rotating-badge{width:100px;height:100px;top:20px;right:20px}.rotating-text{font-size:9px;letter-spacing:1px}.badge-center{width:40px;height:40px}.badge-icon{font-size:16px}}@media(prefers-reduced-motion:reduce){.badge-svg{animation:none}.rotating-text animate{display:none}}@keyframes revealUp{0%{opacity:0;transform:translateY(2rem)}to{opacity:1;transform:translateY(0)}}@keyframes revealFade{0%{opacity:0}to{opacity:1}}.home-container h1{animation:revealUp .9s cubic-bezier(.16,1,.3,1) .1s both}.home-container .subtitle{animation:revealUp .9s cubic-bezier(.16,1,.3,1) .4s both}.top-left-buttons{animation:none}.about-title,.about-text-left p,.about-photo-wrapper,.skills-title,.project-button,.project-label,.contact-left,.contact-form-wrapper,.contact-footer a{opacity:0;transform:translateY(2.5rem);transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1)}.skill-logo{opacity:0;transition:opacity .6s cubic-bezier(.16,1,.3,1)}[data-scroll-dir=up] .about-title,[data-scroll-dir=up] .about-text-left p,[data-scroll-dir=up] .about-photo-wrapper,[data-scroll-dir=up] .skills-title,[data-scroll-dir=up] .project-button,[data-scroll-dir=up] .project-label,[data-scroll-dir=up] .contact-left,[data-scroll-dir=up] .contact-form-wrapper,[data-scroll-dir=up] .contact-footer a{transform:translateY(-2.5rem)}.about-title{background-size:0% 55%;transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1),background-size 1.5s cubic-bezier(.16,1,.3,1) .3s}.about-me-container.active-section .about-title,.about-me-container.active-section .about-text-left p,.about-me-container.active-section .about-photo-wrapper{opacity:1;transform:translateY(0)}.about-me-container.active-section .about-title{background-size:100% 55%}.skills-container.active-section .skills-title{opacity:1;transform:translateY(0)}.skills-container.active-section .skill-logo{opacity:1}.skills-container.active-section .skill-logo:nth-child(1){transition-delay:.1s}.skills-container.active-section .skill-logo:nth-child(2){transition-delay:.2s}.skills-container.active-section .skill-logo:nth-child(3){transition-delay:.3s}.skills-container.active-section .skill-logo:nth-child(4){transition-delay:.4s}.skills-container.active-section .skill-logo:nth-child(5){transition-delay:.5s}.skills-container.active-section .skill-logo:nth-child(6){transition-delay:.6s}.projects-container.active-section .project-button{opacity:1;transform:translateY(0)}.projects-container.active-section .project-label{opacity:.7;transform:translateY(0)}.projects-container.active-section .project-button:hover{transform:scale(1.02)}.contact-wrapper.active-section .contact-left,.contact-wrapper.active-section .contact-form-wrapper,.contact-wrapper.active-section .contact-footer a{opacity:1;transform:translateY(0)}.contact-wrapper.active-section .contact-footer a:hover{transform:scale(1.05)}@media(prefers-reduced-motion:reduce){.home-container h1,.home-container .subtitle,.top-left-buttons{animation:none}.about-title,.about-text-left p,.about-photo-wrapper,.skills-title,.skill-logo,.project-button,.project-label,.contact-left,.contact-form-wrapper,.contact-footer a{opacity:1!important;transform:none!important;transition:none!important}.about-title{background-size:100% 55%!important}}@media(max-width:1024px){html,body,#root{scroll-snap-type:none;height:auto}body,a,button,input,textarea{cursor:auto}input,textarea,[contenteditable]{cursor:text!important}.custom-cursor{display:none!important}.home-container{height:auto;min-height:100svh;scroll-snap-align:unset;scroll-snap-stop:unset}.about-me-container,.skills-container,.projects-container,.contact-container{height:auto;min-height:unset;scroll-snap-align:unset;scroll-snap-stop:unset}.contact-wrapper{min-height:auto;scroll-snap-align:unset;scroll-snap-stop:unset}}@media(min-width:769px)and (max-width:1024px){.navbar{gap:2.5rem}.navbar button{font-size:1.1rem}.about-me-container{padding:3rem 0}.about-me-container .profile-photo{width:18rem;height:24rem}.about-text-left{font-size:.95rem}.skill-logo img{width:16rem;height:16rem}.projects-photo{width:17rem;height:23rem;border-radius:1.6rem}.contact-content{flex-direction:column;align-items:stretch}.contact-left{width:100%;padding:2rem 3rem;align-items:center;text-align:center}.contact-form-wrapper{width:100%;padding:0 3rem}.contact-form{padding-right:0}.contact-footer{gap:3rem}.rotating-badge{position:relative;top:auto;right:auto;transform:none;width:12rem;height:4rem;margin-bottom:1rem}.about-title,.about-text-left p,.about-photo-wrapper,.skills-title,.project-button,.project-label,.contact-left,.contact-form-wrapper,.contact-footer a{transform:translateY(1.8rem)}[data-scroll-dir=up] .about-title,[data-scroll-dir=up] .about-text-left p,[data-scroll-dir=up] .about-photo-wrapper,[data-scroll-dir=up] .skills-title,[data-scroll-dir=up] .project-button,[data-scroll-dir=up] .project-label,[data-scroll-dir=up] .contact-left,[data-scroll-dir=up] .contact-form-wrapper,[data-scroll-dir=up] .contact-footer a{transform:translateY(-1.8rem)}}@media(max-width:768px){.navbar{display:none}.home-container{padding:6rem 2rem 3rem;min-height:unset;justify-content:center;align-items:center;text-align:center}.home-container h1{font-size:2.4rem;margin-bottom:.6rem}.home-container .subtitle{font-size:.95rem;padding:0 1rem}.home-container .subtitle-star{font-size:1.2rem}.top-left-buttons{position:fixed;top:1rem;right:1rem;left:auto;z-index:1001}.trad-button{font-size:1.2rem;padding:.4rem}.about-me-container:before,.skills-container:before,.projects-container:before,.contact-container:before{content:"";display:block;width:3rem;height:2px;background:#ffe57299;margin:0 auto 1.5rem}.about-me-container{padding:1.5rem 0;flex-direction:column;align-items:center}.about-content{flex-direction:column-reverse;align-items:center;padding:0 2rem;height:auto;gap:1.25rem}.about-text-left{align-items:center;text-align:center;padding:0;font-size:1.05rem;line-height:1.5}.about-title{font-size:1.8rem;text-align:center;margin-bottom:.75rem}.about-photo-wrapper{align-self:center;padding-right:0}.about-me-container .profile-photo{width:12rem;height:16rem;border-radius:.75rem}.skills-container{padding:1.5rem 2rem;overflow:visible;flex-direction:column;justify-content:center;align-items:center}.skills-title{font-size:1.5rem;max-width:100%;margin-bottom:1.5rem;position:static;text-align:center}.skills-organic{position:static;display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;width:100%;max-width:20rem;justify-items:center}.skill-logo{position:static!important;top:auto!important;left:auto!important;transform:none!important}.skill-logo img{width:6.5rem;height:6.5rem}.projects-container{padding:1.5rem 2rem;align-items:center;justify-content:center}.projects-image-container{flex-direction:column;align-items:center;gap:1.25rem;padding:0}.projects-photo{width:70vw;max-width:20rem;height:auto;aspect-ratio:5 / 6.65;border-radius:1.25rem;animation:none}.projects-photo:hover{animation:none}.project-button:hover{transform:none}.contact-container{padding:1.5rem 2rem 0}.contact-content{flex-direction:column;align-items:center;gap:1.5rem}.contact-left{width:100%;padding:0;align-items:center;text-align:center}.contact-left .title-text{font-size:1.05rem;text-align:center}.contact-left .text{font-size:.9rem;text-align:center;line-height:1.5}.rotating-badge{position:relative;top:auto;right:auto;transform:none;width:8rem;height:3rem;margin-bottom:.75rem}.contact-form-wrapper{width:100%}.form-label{font-size:1.3rem;padding:.25rem 0 .5rem;text-align:center}.contact-form{gap:.75rem;padding-right:0}.form-group input,.form-group textarea{font-size:1rem;padding:.6rem .8rem}.form-group textarea{min-height:7rem}.submit-button{font-size:.9rem;padding:.75rem 2rem;align-self:center}.success-overlay{right:0;bottom:0}.success-checkmark{width:6rem;height:6rem}.site-footer{padding:1rem}.site-footer-copyright{font-size:.7rem}.contact-footer{gap:1rem;font-size:.7rem;flex-wrap:wrap;justify-content:center}.home-container h1,.home-container .subtitle,.top-left-buttons{animation:none}.about-title,.about-text-left p,.about-photo-wrapper,.skills-title,.skill-logo,.project-button,.project-label,.contact-left,.contact-form-wrapper,.contact-footer a{opacity:1!important;transform:none!important;transition:none!important}.about-title,.form-label{background-size:100% 55%!important}}.color-game{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;font-family:Unbounded,sans-serif;cursor:default!important;overflow:hidden;position:relative}.color-game *{cursor:default!important}.back-btn{position:fixed;top:1.5rem;left:1.5rem;background:transparent;border:1px solid rgba(255,255,255,.2);color:#000;background-color:#fff8e8;padding:.5rem 1rem;border-radius:60rem;cursor:pointer!important;font-size:2rem;transition:border-color .2s,background .2s}.back-btn:hover{background:#ffffff14}.game-wrapper{display:flex;flex-direction:column;justify-content:center;align-items:center;width:calc(100% - 12rem);height:calc(100% - 8rem);background-image:url(/images/color-game-bg1.png);background-size:100% 100%;background-repeat:no-repeat;background-position:center;padding:2.5rem 3rem;box-sizing:border-box;color:#1a1a1a;border-radius:20px;overflow:hidden;position:relative}.game-subtitle{font-size:1.8rem;opacity:1;margin:0;color:#000;flex-shrink:0;margin-top:3rem;font-family:Borel,cursive;font-weight:400;font-style:normal;transition:opacity .3s ease;-webkit-user-select:none;user-select:none}.game-subtitle.hidden{opacity:0;visibility:hidden;pointer-events:none}.color-name-display{font-size:3.5rem;font-weight:700;text-align:center;width:100%;color:#000;flex-shrink:0;font-family:Walter Turncoat,cursive;font-weight:400;font-style:normal;padding-bottom:3rem;-webkit-user-select:none;user-select:none}.picker-row{display:flex;gap:12px;width:50%;height:23rem}.color-square{flex:1;height:23rem;border-radius:15px;position:relative;cursor:crosshair!important;-webkit-user-select:none;user-select:none}.square-cursor{position:absolute;width:2.5rem;height:2.5rem;border-radius:50%;transform:translate(-50%,-50%);pointer-events:none}.lightness-bar{width:24px;height:23rem;border-radius:10px;position:relative;cursor:ns-resize!important;-webkit-user-select:none;user-select:none;flex-shrink:0}.lightness-cursor{position:absolute;left:50%;width:18px;height:8px;border-radius:10px;background:#fff;border:1px solid rgba(0,0,0,.3);transform:translate(-50%,-50%);pointer-events:none;box-shadow:0 1px 4px #0000004d}.validate-btn{background:none;color:#000;border:none;font-size:2rem;font-family:Borel,cursive;font-weight:400;font-style:normal;cursor:pointer!important;transition:opacity .2s;width:12rem;flex-shrink:0;margin-top:1.5rem;position:relative;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none}.validate-text{position:relative;z-index:1}.validate-highlight{position:relative;display:inline-block}.validate-highlight:before{content:"";position:absolute;left:-4px;right:-2px;bottom:26px;height:40%;background:#78dc6473;transform:skew(-4deg) rotate(-1.5deg) scaleX(1.02);border-radius:2px;z-index:-1}.validate-circle{position:absolute;width:100%;height:100%;top:0;left:0;pointer-events:none}.validate-circle ellipse{stroke-dasharray:1;stroke-dashoffset:1;transition:stroke-dashoffset .5s cubic-bezier(.4,0,.2,1);stroke:#0d7809;transform-origin:center;transform:rotate(-10deg)}.validate-btn:hover .validate-circle ellipse{stroke-dashoffset:.08}.result{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%;margin-bottom:0rem}.score-display{display:flex;align-items:baseline;gap:.25rem}.score-number{font-size:6rem;font-weight:700;color:#000;-webkit-user-select:none;user-select:none}.score-max{font-size:2.5rem;opacity:.4;color:#000;-webkit-user-select:none;user-select:none}.score-colors{margin-top:0rem;display:flex;gap:2rem;font-size:.9rem;color:#1a1a1a;align-items:center;width:100%;justify-content:center;font-family:Borel,cursive;font-weight:400;font-style:normal;-webkit-user-select:none;user-select:none}.score-colors>div{display:flex;flex-direction:column;align-items:center;gap:.6rem}.color-swatch-large{width:120px;height:120px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.next-btn{background:none;color:#000;border:none;font-size:1.8rem;font-family:Borel,cursive;font-weight:400;font-style:normal;cursor:pointer!important;transition:opacity .2s;width:12rem;flex-shrink:0;margin-top:4rem;position:relative;display:flex;align-items:center;justify-content:center;line-height:1.6rem}.next-text{position:relative;z-index:1}.next-highlight{position:relative;display:inline-block}.next-highlight:before{content:"";position:absolute;left:-4px;right:-2px;bottom:18px;height:60%;background:#78dc6473;transform:skew(-4deg) rotate(-1.5deg) scaleX(1.02);border-radius:2px;z-index:-1}.next-circle{position:absolute;width:100%;height:100%;top:0;left:0;pointer-events:none}.next-circle ellipse{stroke-dasharray:1;stroke-dashoffset:1;transition:stroke-dashoffset .5s cubic-bezier(.4,0,.2,1);stroke:#0d7809;transform-origin:center;transform:rotate(-10deg)}.next-btn:hover .next-circle ellipse{stroke-dashoffset:.08}.history-container{position:absolute;right:12.5%;top:55%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem}.history-title{font-family:Borel,cursive;font-weight:600;font-style:normal;font-size:1.1rem;text-align:center;margin:0;color:#7b8cd8;-webkit-user-select:none;user-select:none;position:relative;display:inline-block}.history-title:before{content:"";position:absolute;left:-4px;right:-2px;bottom:14px;height:44%;background:#8bc9f067;transform:skew(-4deg) rotate(-1.5deg) scaleX(1.02);border-radius:2px;z-index:-1}.history{display:flex;flex-direction:column;gap:.3rem;font-size:1rem;opacity:1;text-align:center;color:#7b8cd8;flex-shrink:0;font-family:Borel,cursive;font-weight:400;font-style:normal;-webkit-user-select:none;user-select:none}.weather-app{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#d3d9f7;padding:2rem;font-family:Unbounded,sans-serif;position:relative;overflow:hidden}.weather-app:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");opacity:.15;pointer-events:none;z-index:1}.weather-app>*{position:relative;z-index:2}.weather-app *{cursor:auto}.weather-app button{cursor:pointer!important}.weather-app input,.weather-app textarea{cursor:text!important}.weather-app .suggestion-item{cursor:pointer!important}.back-btn{position:fixed;top:1.5rem;left:1.5rem;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);color:#fff;padding:.7rem 1.3rem;border-radius:50px;cursor:pointer!important;font-size:1.5rem;transition:all .3s ease;z-index:100}.back-btn:hover{background:#ffffff4d;transform:translate(-5px)}.weather-wrapper{background:#ffffff26;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:30px;padding:3rem;box-shadow:0 8px 32px #1f26875e;border:1px solid rgba(255,255,255,.18);max-width:500px;width:100%;min-height:500px;display:flex;flex-direction:column;align-items:center}.weather-title{font-size:2.5rem;color:#fff;margin-bottom:.5rem;text-align:center;font-weight:600;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.weather-subtitle{font-size:1rem;color:#ffffffd9;margin-bottom:2rem;text-align:center;font-weight:300}.search-container{position:relative;width:100%;margin-bottom:2rem;display:flex;justify-content:center;align-items:center}.search-circle-btn{width:60px;height:60px;border-radius:50%;background:#fffffff2;border:2px solid rgba(255,255,255,.3);cursor:pointer!important;display:flex;align-items:center;justify-content:center;transition:all .4s ease;box-shadow:0 4px 12px #0000001a;position:absolute;z-index:5}.search-container.open .search-circle-btn{opacity:0;transform:scale(0);pointer-events:none}.search-circle-btn:hover{background:#fff;transform:scale(1.05);box-shadow:0 6px 16px #00000026}.search-icon{width:24px;height:24px;color:#667eea}.search-input{width:60px;height:60px;padding:0;border-radius:50px;border:2px solid rgba(255,255,255,.3);background:#fffffff2;font-size:1rem;font-family:Unbounded,sans-serif;transition:all .5s cubic-bezier(.68,-.55,.265,1.55);box-sizing:border-box;color:#1a1a1a;opacity:0;position:absolute;text-align:center}.search-input.expanded{width:100%;height:auto;padding:1rem 1.5rem;opacity:1;position:relative;text-align:left}.search-input:focus{outline:none;border-color:#fff9;background:#fff;box-shadow:0 4px 12px #0000001a}.search-input::placeholder{color:#0006}.suggestions-list{position:absolute;top:calc(100% + .5rem);left:0;right:0;background:#fff;border-radius:15px;box-shadow:0 8px 24px #00000026;max-height:300px;overflow-y:auto;z-index:10;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.suggestion-loading{padding:1rem 1.5rem;text-align:center;color:#00000080;font-size:.9rem}.suggestion-item{padding:.8rem 1.5rem;cursor:pointer!important;transition:background .2s ease;font-size:.95rem;display:flex;flex-direction:column;gap:.2rem}.suggestion-item:hover,.suggestion-item.selected{background:#667eea1a}.suggestion-item.selected{background:#667eea26}.city-name-suggestion{font-weight:500;color:#1a1a1a}.city-country{font-size:.8rem;color:#0009}.suggestion-item:first-child{border-radius:15px 15px 0 0}.suggestion-item:last-child{border-radius:0 0 15px 15px}.loading{display:flex;flex-direction:column;align-items:center;gap:1rem;color:#fff;margin-top:2rem}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-message{color:#ff6b6b;background:#ffffffe6;padding:1rem 2rem;border-radius:15px;margin-top:2rem;text-align:center;font-size:.95rem}.weather-display{width:100%;color:#fff;animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.weather-header{display:flex;flex-direction:column;align-items:center;margin-bottom:1rem}.city-name{font-size:2rem;margin:0;font-weight:600;text-align:center}.weather-icon{width:150px;height:150px;margin:-1rem 0;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}.temperature{font-size:4rem;font-weight:700;text-align:center;margin:1rem 0;text-shadow:2px 2px 8px rgba(0,0,0,.3)}.weather-description{font-size:1.3rem;text-align:center;margin-bottom:2rem;opacity:.9}.weather-details{display:flex;justify-content:space-around;gap:2rem;background:#ffffff1a;padding:1.5rem;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.detail-item{display:flex;flex-direction:column;align-items:center;gap:.5rem}.detail-label{font-size:.9rem;opacity:.8}.detail-value{font-size:1.5rem;font-weight:600}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:#fff;opacity:.7;margin-top:3rem;text-align:center}.empty-state p:first-child{font-size:4rem;margin:0}.empty-state p:last-child{font-size:1.1rem;margin:0}.suggestions-list::-webkit-scrollbar{width:8px}.suggestions-list::-webkit-scrollbar-track{background:#0000000d;border-radius:10px}.suggestions-list::-webkit-scrollbar-thumb{background:#667eea4d;border-radius:10px}.suggestions-list::-webkit-scrollbar-thumb:hover{background:#667eea80}@media(max-width:768px){.weather-wrapper{padding:2rem;margin:1rem}.weather-title{font-size:2rem}.temperature{font-size:3rem}.city-name{font-size:1.5rem}.weather-details{gap:1rem}}
