: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}}@media (max-width: 900px){.hero-container{max-width:95vw;padding:1rem}.about-skills>div{gap:1rem;flex-wrap:wrap}.projects-list{gap:1rem;flex-wrap:wrap}section{padding:1.2rem!important}}@media (max-width: 600px){.hero-container{max-width:100vw;padding:.5rem;margin:0 auto;text-align:center}.hero-photo{width:100px!important;height:100px!important;margin:0 auto}.about-skills>div{flex-direction:column!important;align-items:center!important;gap:.7rem!important;width:100%;flex-wrap:nowrap!important}.about-skills{flex-direction:column!important;align-items:center!important;gap:.7rem!important;width:100%;display:flex!important;flex-wrap:nowrap!important}.projects-list{flex-direction:column!important;align-items:center!important;gap:1rem!important;width:100%;display:flex!important;flex-wrap:nowrap!important}.project-card{max-width:98vw!important;padding:1rem!important;min-width:0}section{padding:1rem!important;overflow-x:hidden}h1{font-size:1.5rem!important}h2{font-size:1.2rem!important}h3{font-size:1.1rem!important}p,div{font-size:.98rem!important}img{max-width:100%;height:auto}html,body{overflow-x:hidden}}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.projects-list{margin-top:1rem}.project-card{transition:box-shadow .2s,transform .2s}.project-card:hover{box-shadow:0 6px 24px #646cff2e;transform:translateY(-4px) scale(1.03)}#root{max-width:100%;margin:0 auto;padding:1rem;text-align:center;background:transparent!important;overflow-x:hidden}body{background:transparent!important;overflow-x:hidden;margin:0;padding:0}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.hero-container{background:#ffffff2e;box-shadow:0 8px 32px #1f268721;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border-radius:24px;border:1px solid rgba(255,255,255,.18);padding:2.5rem 2rem 2rem;margin-bottom:2rem;margin-left:auto;margin-right:auto;display:flex;flex-direction:column;align-items:center;justify-content:center}.hero-photo{border:3px solid #fff;background:#ffffff40;display:block;margin-left:auto;margin-right:auto}.contact-hero-btn{background:#646cffd9;color:#fff;font-weight:600;border:none;border-radius:8px;padding:.8rem 2rem;font-size:1.1rem;box-shadow:0 2px 8px #1f26871f;cursor:pointer;transition:background .2s}.contact-hero-btn:hover{background:#646cff}.about-skills div[title]{display:flex;flex-direction:column;align-items:center;justify-content:center;background:#ffffff2e;border-radius:12px;padding:1rem 1.2rem;box-shadow:0 2px 8px #1f26871a;min-width:80px;font-size:1rem;transition:box-shadow .2s}.about-skills div[title]:hover{box-shadow:0 4px 16px #646cff2e;background:#646cff14}.about-tools div{background:#ffffff21;border-radius:8px;padding:.7rem 1.2rem;box-shadow:0 1px 4px #1f268714;margin-bottom:.5rem}@media screen and (min-width: 1025px){.hero-container{padding:2.5rem;max-width:900px}.about-skills div[title]{min-width:100px}}@media screen and (max-width: 1024px){.hero-container{max-width:90%;padding:2rem}.hero-photo{width:140px!important;height:140px!important}h1{font-size:2rem!important}h2{font-size:1.5rem!important}.about-skills>div{gap:1rem;flex-wrap:wrap;justify-content:center}.project-card{max-width:45%}}@media screen and (max-width: 767px){.hero-container{max-width:95%;padding:1.5rem}.hero-photo{width:120px!important;height:120px!important}h1{font-size:1.8rem!important}h2{font-size:1.3rem!important}h3{font-size:1.1rem!important}.project-card{max-width:100%;margin:.5rem 1rem}.contact-hero-btn{padding:.6rem 1.5rem;font-size:1rem}section{padding:1.5rem 1rem!important}.about-skills div[title]{min-width:70px;padding:.8rem}}@media screen and (max-width: 480px){.hero-container{max-width:100%;padding:1rem;margin:.5rem}.hero-photo{width:100px!important;height:100px!important}h1{font-size:1.5rem!important}h2{font-size:1.2rem!important}h3{font-size:1rem!important}p{font-size:.95rem!important}.about-skills>div{flex-direction:column;align-items:center;gap:.8rem}.projects-list{flex-direction:column;align-items:center;gap:1rem}.project-card{width:95%;margin:.5rem 0;padding:1rem!important}.contact-hero-btn{width:100%;margin:.5rem 0;padding:.6rem 1rem}section{padding:1rem .5rem!important}.about-skills div[title]{width:100%;max-width:150px}img{max-width:100%;height:auto}}@media screen and (max-height: 480px) and (orientation: landscape){.hero-container{padding:1rem}.hero-photo{width:80px!important;height:80px!important}section{min-height:auto!important}}*{box-sizing:border-box;max-width:100%}.container,section{width:100%;margin-left:auto;margin-right:auto;overflow-x:hidden}.about-skills,.projects-list{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;padding:.5rem}img{max-width:100%;height:auto;display:block}.navbar-glass{width:100%;position:fixed;top:0;left:0;z-index:100;background:#ffffff26;box-shadow:0 8px 32px #1f26875e;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:0 0 16px 16px;border:1px solid rgba(255,255,255,.18)}.nav-container{max-width:1280px;margin:0 auto;padding:0rem 1rem;display:flex;justify-content:space-between;align-items:center}.logo-container{display:flex;align-items:center}.nav-logo{height:40px;width:auto}.navbar-menu{display:flex;justify-content:center;align-items:center;list-style:none;margin:0;padding:1rem 0;gap:1rem}.navbar-menu li{margin:0}.navbar-menu a{color:#646cff;text-decoration:none;font-weight:500;font-size:1.1rem;padding:.5rem 1rem;border-radius:8px;transition:background .2s,color .2s;white-space:nowrap}.navbar-menu a:hover{background:#ffffff4d;color:#646cff}.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem;z-index:102}.hamburger{width:24px;height:20px;position:relative;display:flex;flex-direction:column;justify-content:space-between}.hamburger span{display:block;height:2px;width:100%;background-color:#646cff;transition:all .3s ease}.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}@media screen and (max-width: 768px){.menu-toggle{display:block}.navbar-menu{position:fixed;top:0;right:-100%;width:70%;height:100vh;background:#ffffffe6;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);flex-direction:column;padding:80px 2rem;transition:.3s ease-in-out;box-shadow:-5px 0 15px #0000001a}.navbar-menu.active{right:0}.navbar-menu li{margin:1rem 0}.navbar-menu a{font-size:1.1rem;width:100%;display:block;text-align:center}}@media screen and (max-width: 480px){.navbar-menu{width:85%}.nav-logo{height:32px}}.footer-glass{width:100%;background:#ffffff26;box-shadow:0 -8px 32px #1f26872b;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:16px 16px 0 0;border-top:1px solid rgba(255,255,255,.18);padding:1.5rem 0 1rem;margin-top:2rem;display:flex;justify-content:center;position:static;left:unset;bottom:unset;z-index:99;animation:floating-footer 3s ease-in-out infinite alternate}@keyframes floating-footer{0%{transform:translateY(0) scale(1);box-shadow:0 -8px 32px #1f26872b}50%{transform:translateY(-8px) scale(1.01);box-shadow:0 2px 18px #646cff21}to{transform:translateY(0) scale(1);box-shadow:0 -8px 32px #1f26872b}}.footer-content{display:flex;flex-direction:column;align-items:center;gap:1rem;max-width:1280px;width:100%;margin:0 auto}.footer-social a{display:inline-flex;align-items:center;justify-content:center;margin:0 .7rem;width:44px;height:44px;border-radius:50%;background:#ffffff2e;transition:box-shadow .2s,background .2s;box-shadow:0 1px 4px #1f268714}.footer-social a:hover{box-shadow:0 2px 8px #646cff2e;background:#646cff1f}.footer-social svg{width:28px;height:28px;display:block}.footer-copy{font-size:.95rem;opacity:.8}.vertical-timeline *{box-sizing:border-box}.vertical-timeline{width:95%;max-width:1170px;margin:0 auto;position:relative;padding:2em 0}.vertical-timeline:after{content:"";display:table;clear:both}.vertical-timeline:before{content:"";position:absolute;top:0;left:18px;height:100%;width:4px;background:var(--line-color)}.vertical-timeline.vertical-timeline--one-column-right:before{right:18px;left:unset}@media only screen and (min-width:1170px){.vertical-timeline.vertical-timeline--two-columns{width:90%}.vertical-timeline.vertical-timeline--two-columns:before{left:50%;margin-left:-2px}}.vertical-timeline-element{position:relative;margin:2em 0}.vertical-timeline-element>div{min-height:1px}.vertical-timeline-element:after{content:"";display:table;clear:both}.vertical-timeline-element:first-child{margin-top:0}.vertical-timeline-element:last-child{margin-bottom:0}@media only screen and (min-width:1170px){.vertical-timeline-element{margin:4em 0}.vertical-timeline-element:first-child{margin-top:0}.vertical-timeline-element:last-child{margin-bottom:0}}.vertical-timeline-element-icon{position:absolute;top:0;left:0;width:40px;height:40px;border-radius:50%}.vertical-timeline-element-icon.shadow-size-small{box-shadow:0 0 0 2px #fff,inset 0 1px #00000014,0 2px 0 4px #0000000d}.vertical-timeline-element-icon.shadow-size-medium{box-shadow:0 0 0 3px #fff,inset 0 2px #00000014,0 3px 0 5px #0000000d}.vertical-timeline-element-icon.shadow-size-large{box-shadow:0 0 0 4px #fff,inset 0 2px #00000014,0 4px 0 6px #0000000d}.vertical-timeline--one-column-right .vertical-timeline-element-icon{right:0;left:unset}.vertical-timeline-element-icon svg{display:block;width:24px;height:24px;position:relative;left:50%;top:50%;margin-left:-12px;margin-top:-12px}@media only screen and (min-width:1170px){.vertical-timeline--two-columns .vertical-timeline-element-icon{width:60px;height:60px;left:50%;margin-left:-30px}}.vertical-timeline-element-icon{-webkit-transform:translateZ(0);-webkit-backface-visibility:hidden}.vertical-timeline--animate .vertical-timeline-element-icon.is-hidden{visibility:hidden}.vertical-timeline--animate .vertical-timeline-element-icon.bounce-in{visibility:visible;-webkit-animation:cd-bounce-1 .6s;-moz-animation:cd-bounce-1 .6s;animation:cd-bounce-1 .6s}@-webkit-keyframes cd-bounce-1{0%{opacity:0;-webkit-transform:scale(.5)}60%{opacity:1;-webkit-transform:scale(1.2)}to{-webkit-transform:scale(1)}}@-moz-keyframes cd-bounce-1{0%{opacity:0;-moz-transform:scale(.5)}60%{opacity:1;-moz-transform:scale(1.2)}to{-moz-transform:scale(1)}}@keyframes cd-bounce-1{0%{opacity:0;-webkit-transform:scale(.5);-moz-transform:scale(.5);-ms-transform:scale(.5);-o-transform:scale(.5);transform:scale(.5)}60%{opacity:1;-webkit-transform:scale(1.2);-moz-transform:scale(1.2);-ms-transform:scale(1.2);-o-transform:scale(1.2);transform:scale(1.2)}to{-webkit-transform:scale(1);-moz-transform:scale(1);-ms-transform:scale(1);-o-transform:scale(1);transform:scale(1)}}.vertical-timeline-element-content{position:relative;margin-left:60px;background:#fff;border-radius:.25em;padding:1em;box-shadow:0 3px #ddd}.vertical-timeline--one-column-right .vertical-timeline-element-content{margin-right:60px;margin-left:unset}.vertical-timeline-element--no-children .vertical-timeline-element-content{background:0 0;box-shadow:none}.vertical-timeline-element-content:after{content:"";display:table;clear:both}.vertical-timeline-element-content h2{color:#303e49}.vertical-timeline-element-content .vertical-timeline-element-date,.vertical-timeline-element-content p{font-size:13px;font-size:.8125rem;font-weight:500}.vertical-timeline-element-content .vertical-timeline-element-date{display:inline-block}.vertical-timeline-element-content p{margin:1em 0 0;line-height:1.6}.vertical-timeline-element-title,.vertical-timeline-element-subtitle{margin:0}.vertical-timeline-element-content .vertical-timeline-element-date{float:left;padding:.8em 0;opacity:.7}.vertical-timeline-element-content-arrow{content:"";position:absolute;top:16px;right:100%;height:0;width:0;border:7px solid transparent;border-right:7px solid #fff}.vertical-timeline--one-column-right .vertical-timeline-element-content-arrow{content:"";position:absolute;top:16px;right:unset;left:100%;height:0;width:0;border:7px solid transparent;border-left:7px solid #fff}.vertical-timeline--one-column-right .vertical-timeline-element-content:before{left:100%;border-left:7px solid #fff;border-right:unset}.vertical-timeline-element--no-children .vertical-timeline-element-content:before{display:none}.vertical-timeline-element--no-children .vertical-timeline-element-content-arrow{display:none}@media only screen and (min-width:768px){.vertical-timeline-element-content h2{font-size:20px;font-size:1.25rem}.vertical-timeline-element-content p{font-size:16px;font-size:1rem}.vertical-timeline-element-content .vertical-timeline-element-date{font-size:14px;font-size:.875rem}}@media only screen and (min-width:1170px){.vertical-timeline--two-columns .vertical-timeline-element-content{margin-left:0;padding:1.5em;width:44%}.vertical-timeline--two-columns .vertical-timeline-element-content-arrow{top:24px;left:100%;transform:rotate(180deg)}.vertical-timeline--two-columns .vertical-timeline-element-content .vertical-timeline-element-date{position:absolute;width:100%;left:124%;top:6px;font-size:16px;font-size:1rem}.vertical-timeline--two-columns .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content,.vertical-timeline--two-columns .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content{float:right}.vertical-timeline--two-columns .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content-arrow,.vertical-timeline--two-columns .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content-arrow{top:24px;left:auto;right:100%;transform:rotate(0)}.vertical-timeline--one-column-right .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content-arrow,.vertical-timeline--one-column-right .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content-arrow{top:24px;left:100%;right:auto;transform:rotate(0)}.vertical-timeline--two-columns .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content .vertical-timeline-element-date,.vertical-timeline--two-columns .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content .vertical-timeline-element-date{left:auto;right:124%;text-align:right}}.vertical-timeline--animate .vertical-timeline-element-content.is-hidden{visibility:hidden}.vertical-timeline--animate .vertical-timeline-element-content.bounce-in{visibility:visible;-webkit-animation:cd-bounce-2 .6s;-moz-animation:cd-bounce-2 .6s;animation:cd-bounce-2 .6s}@media only screen and (min-width:1170px){.vertical-timeline--two-columns.vertical-timeline--animate .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content.bounce-in,.vertical-timeline--two-columns.vertical-timeline--animate .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content.bounce-in{-webkit-animation:cd-bounce-2-inverse .6s;-moz-animation:cd-bounce-2-inverse .6s;animation:cd-bounce-2-inverse .6s}}@media only screen and (max-width:1169px){.vertical-timeline--animate .vertical-timeline-element-content.bounce-in{visibility:visible;-webkit-animation:cd-bounce-2-inverse .6s;-moz-animation:cd-bounce-2-inverse .6s;animation:cd-bounce-2-inverse .6s}}@-webkit-keyframes cd-bounce-2{0%{opacity:0;-webkit-transform:translateX(-100px)}60%{opacity:1;-webkit-transform:translateX(20px)}to{-webkit-transform:translateX(0)}}@-moz-keyframes cd-bounce-2{0%{opacity:0;-moz-transform:translateX(-100px)}60%{opacity:1;-moz-transform:translateX(20px)}to{-moz-transform:translateX(0)}}@keyframes cd-bounce-2{0%{opacity:0;-webkit-transform:translateX(-100px);-moz-transform:translateX(-100px);-ms-transform:translateX(-100px);-o-transform:translateX(-100px);transform:translate(-100px)}60%{opacity:1;-webkit-transform:translateX(20px);-moz-transform:translateX(20px);-ms-transform:translateX(20px);-o-transform:translateX(20px);transform:translate(20px)}to{-webkit-transform:translateX(0);-moz-transform:translateX(0);-ms-transform:translateX(0);-o-transform:translateX(0);transform:translate(0)}}@-webkit-keyframes cd-bounce-2-inverse{0%{opacity:0;-webkit-transform:translateX(100px)}60%{opacity:1;-webkit-transform:translateX(-20px)}to{-webkit-transform:translateX(0)}}@-moz-keyframes cd-bounce-2-inverse{0%{opacity:0;-moz-transform:translateX(100px)}60%{opacity:1;-moz-transform:translateX(-20px)}to{-moz-transform:translateX(0)}}@keyframes cd-bounce-2-inverse{0%{opacity:0;-webkit-transform:translateX(100px);-moz-transform:translateX(100px);-ms-transform:translateX(100px);-o-transform:translateX(100px);transform:translate(100px)}60%{opacity:1;-webkit-transform:translateX(-20px);-moz-transform:translateX(-20px);-ms-transform:translateX(-20px);-o-transform:translateX(-20px);transform:translate(-20px)}to{-webkit-transform:translateX(0);-moz-transform:translateX(0);-ms-transform:translateX(0);-o-transform:translateX(0);transform:translate(0)}}
