body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}body,html{font-family:Mooli,serif;font-weight:400;height:100%;margin:0;padding:0}.App{align-items:center;background:linear-gradient(180deg,#c0ebfe 0,#c0ebfe 25%,#f8e6d4 50%,#f7b1c1 75%,#a281f5);display:flex;flex-direction:column;justify-content:center;min-height:100vh}html{scroll-behavior:smooth}.banner{background-position:50%;background-size:cover;height:145px;width:100%}.sidebar{align-items:top;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;flex-direction:column;gap:2rem;height:100vh;justify-content:center;left:0;padding:1rem 0;position:fixed;top:0;width:120px;z-index:1000}.sidebar a{font-weight:700;text-decoration:none}.sidebar a,.sidebar a:hover{border-radius:999px;color:#000;padding:.5rem 1rem;transition:all .3s ease}.sidebar a:hover{background-color:#ffffff4d;box-shadow:0 0 12px #706b6bb3}.section{align-items:center;box-sizing:border-box;display:flex;flex-direction:column;min-height:100vh;padding:4rem 1rem;scroll-snap-align:start;text-align:center}.rotating-title-wrapper{display:inline-block;min-height:1.5em;position:relative}.rotating-title{display:inline-block;max-width:100%;overflow:hidden;transition:none;will-change:opacity,transform}.fade-in{animation:fadeIn .4s ease-in forwards}.fade-out{animation:fadeOut .4s ease-out forwards}.hero h1{font-size:2.5rem;margin:.5rem 0}.hero p{font-size:1.2rem;font-weight:600}.hero-section{justify-content:flex-start;margin-top:1rem;min-height:100vh;position:relative;text-align:center}.hero-content h1,.hero-section{align-items:center;display:flex;flex-direction:column}.hero-content h1{font-size:2.5rem;margin-bottom:1rem}.hero-content h1 span.rotating-title{display:inline-block;padding-bottom:1rem;text-align:center}@media (max-width:600px){.hero-content h1{font-size:1.9rem}}.hero-content p{font-size:1.2rem;margin-bottom:1.75rem;margin-top:1rem;max-width:600px}.scroll-indicator{animation:bounce 2s infinite;bottom:20px;left:50%;position:relative;transform:translateX(-50%);z-index:10}.arrow{border-bottom:4px solid #333;border-left:4px solid #333;display:block;height:24px;margin:0 auto;transform:rotate(-45deg);width:24px}@keyframes bounce{0%,20%,50%,80%,to{transform:translate(-50%)}40%{transform:translate(-50%,10px)}60%{transform:translate(-50%,5px)}}.code-demo{border-radius:10px;box-shadow:0 0 15px #0006;color:#000;font-family:Mooli,monospace;height:350px;margin-bottom:2rem;margin-top:5rem;max-width:600px;padding:1rem;width:90%}.code-demo textarea{background:#2e2e2e;height:80px;margin-top:.5rem;padding:.5rem;resize:none;width:90%}.code-demo button,.code-demo textarea{border:none;border-radius:5px;color:#fff}.code-demo button{background-color:#09437e;cursor:pointer;font-weight:700;margin-bottom:1rem;margin-top:1.5rem;padding:.5rem 1rem}.code-demo .output{background:#111;border-radius:5px;color:#fff;height:1.5rem;margin-top:1rem;padding:.5rem}.project{margin-bottom:3rem;max-width:800px;text-align:left}.project-list{font-size:1.1rem;list-style:none;padding:0}#projects{margin:0 auto;max-width:1000px;width:100%}.project-media{display:flex;justify-content:center;margin-top:1rem}.project-media iframe,.project-media video{border-radius:8px;box-shadow:0 2px 6px #00000026;max-width:700px;width:100%}.project-media.slideshow{display:flex;justify-content:center;margin-top:1rem;position:relative;z-index:0}.project-media.slideshow img{border-radius:8px;box-shadow:0 2px 6px #00000026;display:none;height:400px;max-width:700px;object-fit:contain;width:100%}.project-media.slideshow img.active{animation:fade .8s ease-in-out;display:block}.project-media.slideshow img.inactive{display:none}@keyframes fade{0%{opacity:.3}to{opacity:1}}.project-media.slideshow .controls{bottom:10px;display:flex;gap:6px;position:absolute;right:10px;z-index:2}.project-media.slideshow .controls button{background:#0009;border:none;border-radius:5px;color:#fff;cursor:pointer;padding:.3rem .7rem}.project-media.slideshow .counter{background:#0009;border-radius:12px;color:#fff;font-size:.9rem;font-weight:700;padding:.2rem .6rem;position:absolute;right:15px;top:10px;z-index:2}@media (max-width:600px){.project-media iframe,.project-media video,.project-media.slideshow img{aspect-ratio:auto;border-radius:6px;height:16rem;max-width:100%}}.project-text{align-items:center;display:flex;flex-direction:column;margin-top:1rem;text-align:center}#connect{padding-top:1rem}.resume-downloads{align-items:center;display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem;margin-top:3rem}.download-button{background-color:#333;border-radius:8px;padding:.7rem 1rem;width:200px}.download-button,.download-project{color:#fff;text-align:center;text-decoration:none}.download-project{background-color:#444;border-radius:6px;font-size:.9rem;padding:.5rem .8rem;transition:background-color .2s ease,transform .1s ease;width:-webkit-fit-content;width:fit-content}.download-project:hover{background-color:#555;transform:translateY(-2px)}.socials a{color:#333;font-size:1.2rem;margin:0 1rem}.button,.socials a{text-decoration:none}.button{background-color:#ffffff4d;border-radius:999px;box-shadow:0 0 8px #706b6b66;color:#000;display:inline-block;font-weight:700;margin:.25rem;padding:.5rem 1rem;transition:all .3s ease}.button:hover{background-color:#ffffff80;box-shadow:0 0 12px #706b6bb3}.social-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:1rem}.contact-form{display:flex;flex-direction:column;gap:.5rem;max-width:400px;width:100%}.contact-form input,.contact-form textarea{border:none;border-radius:6px;font-family:Mooli,serif;font-size:.85rem;padding:.75rem}.contact-form button{background-color:#333;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:.8rem}.about p{font-size:1.1rem;font-weight:500;line-height:1.6;margin:1rem auto;max-width:700px}.about-header{align-items:center;display:flex;flex-direction:row;gap:1rem;justify-content:center;margin-bottom:2.5rem;max-width:700px;width:100%}.profile-photo{align-items:center;border-radius:50%;height:100px;margin-left:1rem;margin-top:1.5rem;object-fit:cover;object-position:center;object-position:top;transform:scale(2);width:100px}.about-content{font-size:1rem;line-height:1.6}.toggle-button{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background-color:#ffffff4d;border:none;border-radius:5px;cursor:pointer;font-size:1.5rem;left:1rem;padding:.5rem 1rem;position:fixed;top:1rem;z-index:1100}.sidebar{transform:translateX(-100%);transition:transform .3s ease}.sidebar.open{transform:translateX(0)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.site-footer{color:#030303;font-size:.8rem;margin-top:3rem;padding-bottom:1rem;text-align:center}
/*# sourceMappingURL=main.d0c57293.css.map*/