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}.page{background-image:url(/static/media/portfolio_background.6446c52009c867a6a52a.png);background-repeat:repeat-y;background-size:100% 40%;display:flex;flex-direction:column;font-size:calc(5px + 3vmin);height:100%;overflow-x:hidden;width:100%}.page::-webkit-scrollbar{background-color:#090909}.page::-webkit-scrollbar-thumb{background:#696969}.fixed-back-btn{align-items:center;background-color:#292929;border-radius:50%;color:#e7e7e7;display:flex;height:60px;justify-content:center;left:90%;position:fixed;top:90%;width:60px}.fixed-back-btn:hover{cursor:pointer}.arrow-down{animation:Arrow-float 1.3s ease .5s infinite alternate none;color:#1f1f1f;display:flex;height:40px;justify-content:center;margin-top:30px;position:relative}.arrow-down img:hover{animation:none;cursor:pointer}@media screen and (max-width:600px){.arrow-down{display:none}}.title-container{display:flex;justify-content:center}.title{background-color:#292929;border-radius:1.3rem;color:#fff;font-family:Bebas Neue,sans-serif;font-size:90%;font-weight:100;padding:7px 30px;width:auto}@media screen and (max-width:600px){.title{font-size:140%;margin-bottom:50px;margin-top:50px}}.construction-page{align-items:center;display:flex;flex-direction:column;font-size:20px;font-weight:700;justify-self:center}.construction-page,.construction-pic-container{height:100%;width:100%}.construction-pic{align-items:center;display:flex;height:100%;justify-self:center;width:50%}@media screen and (max-width:600px){.construction-pic{margin-top:70px;width:100%}}.header{align-items:center;background-color:#1f1f1f;display:flex;height:80px;justify-content:center;left:0;opacity:95%;position:fixed;top:0;width:100%;z-index:2}.header-block{align-self:space-between;background-image:url(/static/media/background-dark.86ee0daf6c38a02d2a87.png);background-size:100% 132%;color:#fff;height:80vh;padding:10px 20px;z-index:3}.header-contents{display:flex;justify-content:space-between}.header-greeting{align-items:center;color:#fff;height:56vh;justify-content:space-around;margin-left:4%;width:80%}.greeting{align-items:end;display:flex;font-size:90%;height:30%}.name{display:flex;font-family:Bebas Neue,sans-serif;font-size:5em;justify-content:start;margin-top:-2%}.quick-contact{align-items:center;display:flex;flex-direction:column;justify-content:center;margin-bottom:4%;margin-right:4%;padding:0;z-index:5}.quick-contact p:hover{color:#61dafb;cursor:pointer}.hidden-header-page-links{align-content:center;display:flex;font-size:70%;justify-content:space-around;width:100%}.hidden-header-page-links p{color:#fff;font-size:15px;padding:10px}.hidden-header-page-links p:hover{background-color:#467fb4c0;border-radius:3%;cursor:pointer}.header-page-links{display:flex;justify-content:space-around;width:100%;z-index:6}.header-page-links p{border-radius:3%;font-size:15px;padding:10px}.header-page-links p:hover{background-color:#467fb4c0;cursor:pointer}.header-svg{inset:0;opacity:30%;position:absolute;z-index:3}.static-header{align-items:start;display:flex;height:15vh;justify-content:center;width:100%}.logo-and-links{align-items:center;display:flex;justify-content:space-between;width:40%}.logo{height:45px;margin-left:1%;margin-top:1.9%;width:90px}.hamburger-menu{z-index:3}.hamburger-menu:hover{cursor:pointer}.menu-container{align-items:stretch;background-color:#3e9ad0;color:#fff;display:flex;flex-direction:column;margin-left:-60px;margin-top:10px;padding:15px 10px;position:absolute}.menu-container div{padding:15px}.menu-container div:hover{background-color:#d5e1fe;color:#112535}@media screen and (max-width:900px) and (max-height:1000px){.name{flex-direction:column}.last-name{margin-left:1%;margin-top:-8%}.logo-and-links{width:80%}}@media screen and (max-width:600px){.header-page-links,.hidden-header-page-links{visibility:hidden}.logo-and-links{width:90%}.header-contents{flex-direction:column}.greeting{height:15%}.quick-contact{flex-direction:row;justify-content:space-around}.name{font-size:6em}.logo{height:35px;width:60px}}.footer-container{align-items:center;background-color:#090909;color:#f0f0f0b6;display:flex;font-size:60%;height:15vh;justify-content:space-evenly}.profile-container{flex-direction:column;margin-bottom:80px;width:100%}.profile,.profile-container{align-items:center;display:flex;justify-content:center}.profile{size:70%;height:62%;width:80%}@media screen and (max-width:900px){.profile{height:80%;width:90%}}@media screen and (max-width:700px){.profile{align-items:center;flex-direction:column;height:100%;justify-content:start}}@media screen and (max-width:600px){.profile-container{height:100%;margin-bottom:0}}.button-container{align-items:center;margin:2%;width:8%}.blurb-button,.button-container{display:flex;justify-content:center}.blurb-button{border-radius:50%;cursor:pointer;height:30px;width:30px;z-index:2}.blurb-button:hover{color:#afafaf}.blurb-container{align-items:start;animation:slide_in_left 1s ease 1 forwards;display:flex;flex-direction:column;height:100%;justify-content:center;width:60%}.blurb-title{animation:fade_in 2.5s ease 1 forwards;font-size:3rem}.blurb{border-radius:3%;color:#000;height:100%;overflow:hidden;width:550px}.blurb p{color:grey;display:flex;font-size:20px;justify-content:start;text-align:justify}.blurb span{animation:fade_in 3.5s ease 1 forwards;font-size:23px}.attributes{animation:slide_in_left 1s ease 1 forwards;display:flex;flex-direction:column;font-size:20px;justify-content:center;width:80%}.attribute-label{flex-wrap:wrap}.dotpoint-container{font-size:20px;height:30px}@media screen and (max-width:1300px){.blurb{width:100%}}@media screen and (max-width:900px){.blurb-container{display:flex;justify-content:center;width:100%}.blurb-title{font-size:2rem}.blurb{height:100%;width:90%}.blurb p{font-size:17px}.dotpoint-container{font-size:15px;height:40px}.attributes{width:90%}}.pic-container{width:50%}.profile-pic{position:relative}.smile-pic{animation:slide_in_right 1s ease 1 forwards;height:440px;width:500px;z-index:1}.candid-pic{animation:slide_in_candid_pic 1.3s ease 1 forwards;height:300px;margin-left:360px;margin-top:-250px;opacity:70%;width:250px}@media screen and (max-width:1300px){.smile-pic{height:370px;margin-left:20px;width:400px}.candid-pic{height:170px;margin-left:300px;width:150px}}@media screen and (max-width:900px){.smile-pic{height:310px;margin-left:-30px;width:350px}.candid-pic{height:170px;margin-left:190px;width:150px}}@media screen and (max-width:600px){.pic-container{display:flex;justify-content:center;margin-left:-50px;margin-top:20px;width:95%}.smile-pic{height:330px;margin-left:0;width:330px}.candid-pic{height:170px;margin-left:-120px;margin-top:180px;width:150px}}.project-container{align-items:center;display:flex;flex-direction:column;margin-top:30px}.project-grid{flex-wrap:wrap;max-width:1150px}.bottom-grid,.project-grid{display:flex;justify-content:center}.bottom-grid{grid-column:span 3}.project-card{animation:slide_in_bottom 1.3s ease 1 forwards;background-color:#f7f7f7;border-radius:1rem;height:450px;margin:15px;transition:background-color .2s ease-in-out;width:350px}.project-card:hover{background-color:#c9c9c9c7;cursor:pointer}.project-card img:hover{opacity:80%}.project-card img{height:60%;transition:opacity .2s ease-in-out;width:100%}.desc-container{align-items:start;display:flex;flex-direction:column;margin-left:5px}.project-title{color:#585961c2;font-size:25px;font-weight:700}.project-desc{color:#5198cd;font-size:17px;font-weight:600;height:10%;width:auto}.project-date{color:#888a96d0;font-size:13px;margin:5px}.skill-grid{display:grid;grid-template-columns:33% 33% 33%;width:100%}.skill{background-color:#e4e3e3;border-radius:2rem;color:#969595;display:flex;font-size:50%;justify-content:center;margin:4px}@media screen and (max-width:600px){.skill{font-size:20px}}.page-container{font-size:calc(5px + 3vmin);overflow-x:hidden;width:100%}.page-container,.project-page{display:flex;flex-direction:column}.project-page{align-items:center;margin-top:120px;text-align:justify;width:70%}.project-image-container{color:#080600;display:flex;font-family:Gelasio,serif;font-size:120px;font-weight:500;justify-content:center;text-align:center;width:80%}.project-banner{height:110px;width:95%}.project-page-desc-container{text-align:left;width:70%}.project-page-desc-container h2{font-family:Gelasio,serif;margin-bottom:0;margin-top:80px}.project-page-desc-container span{font-family:Gelasio,serif;margin-left:1px}.project-page-desc{font-size:20px;margin-top:15px}@media screen and (max-width:1200px){.project-banner{height:70px}}@media screen and (max-width:900px){.project-banner{height:70px}}@media screen and (max-width:600px){.project-page{margin-top:90px;width:100%}.project-image-container{width:95%}.project-banner{height:50px}}.caesar-page{background-color:#fff5ea8e}.caesar-column{display:flex;justify-content:center}.column{width:15%}.caesar-subtitle,.caesar-title-container{color:#c4930f}.caesar-intro-container{display:flex;font-size:70%;justify-content:center;width:70%}.falling-leaves{height:100vh;left:0;overflow:hidden;pointer-events:none;position:fixed;top:0;width:100%;z-index:-1}.falling-leaf-svg{animation:leaf_fall 12s linear infinite;height:30px;position:absolute;width:30px}.falling-leaf-svg:first-child{animation-delay:0s;left:5%}.falling-leaf-svg:nth-child(2){animation-delay:8.75s;left:8%}.falling-leaf-svg:nth-child(3){animation-delay:4.8s;left:15%}.falling-leaf-svg:nth-child(4){animation-delay:5.25s;left:83%}.falling-leaf-svg:nth-child(5){animation-delay:11.4s;left:93%}.leaf{animation:none}@media screen and (max-width:600px){.caesar-intro-container{width:90%}.caesar-helper{align-items:center;display:flex;font-size:20px;width:100%}}.caesar-function-container{align-items:center;border-radius:1rem;display:flex;flex-direction:column;padding:10px 5px 30px;width:75%}.caesar-function{align-items:center;display:flex;font-size:25px;height:330px;justify-content:center;text-align:start;width:100%}.cipher-form{height:250px;margin-left:30px;margin-right:30px;width:450px}.ciphertext-input{font-size:20px;height:150px;width:90%}.cipher-solve-btn{background-color:#947231;color:#fff;font-size:20px;height:35px;width:90%}@media screen and (max-width:600px){.caesar-function-container{height:150%;width:90%}.caesar-function{flex-direction:column;height:700px}.encode-function{height:600px}.cipher-form{height:380px;margin-top:0;width:330px}.ciphertext-input{height:200px}.cipher-solve-btn{height:65px;width:40%}}.cipher-result-container{word-wrap:break-word;font-weight:500;height:250px;overflow-wrap:break-word;width:450px;word-break:break-word}.cipher-result{background-color:#f5ebd1;height:150px;width:90%}.cipher-result div{color:#16130a;font-weight:600;padding:10px}.cipher-result span{font-size:20px;font-weight:400}.cipher-fail{animation:wrong_shake .5s ease 1 normal;color:#8f1010;font-size:24px;font-weight:700}.copy-container{display:flex;justify-content:end;width:90%}@media screen and (max-width:600px){.cipher-result-container{width:330px}}.encode-decode-btn{display:flex;font-size:24px;justify-content:center;width:30%}.decode-btn{border-radius:0 .5rem .5rem 0;padding:0 10px 5px}.encode-btn{border-radius:.5rem 0 0 .5rem;padding:0 10px 5px}.selected-btn{background-color:#9b7b2f}.unselected-btn{background-color:#726702;box-shadow:inset 2px -2px #505050;color:#fff}.unselected-btn:hover{cursor:pointer}.random-suggestion{color:#423512;font-size:15px;font-weight:400;margin-left:10px}.stack-title{font-weight:600}@media screen and (max-width:600px){.encode-decode-btn{width:80%}}.swing-page{background-color:#f8ffea8e}.swing-subtitle,.swing-title-container{color:#096b04;font-family:Times New Roman,Times,serif}.contact-container{animation:slide_in_bottom 1.6s ease 1 forwards;margin-bottom:100px}.contact-container,.contact-grid{display:flex;justify-content:center}.contact-grid{flex-wrap:wrap;margin-top:50px;width:100%}.contact-card{align-items:center;background-color:#fff;border-radius:4%;box-shadow:3px 2px 2px grey;display:flex;flex-direction:column;height:200px;margin:20px;width:300px}.contact-card svg{margin-top:20px}.contact-card p{font-size:25px;font-weight:600;margin-bottom:0;margin-top:35px}.contact-card:hover{color:#598fcb;cursor:pointer}.contact{color:#292929;font-size:20px}@media screen and (max-width:600px){.contact-grid{align-items:center;flex-direction:column;margin-top:0}.contact-card{height:170px;width:270px}.contact{font-size:17px;margin-bottom:10px}}.line{background:linear-gradient(90deg,#efefef,#1d1d1d 50%,#efefef);border-radius:3rem;border-width:50px;height:1px;margin-bottom:65px;margin-top:65px;width:90%}.App{text-align:center}.App-logo{height:30vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-link{color:#61dafb}.effect-container{--effect-name:ripple;--effect-duration:500ms;--effect-top:0;--effect-left:0;--effect-height:100px;--effect-width:100px;--effect-color:"fff";overflow:hidden;position:relative}.effect-container:before{background:var(--effect-color);content:"";height:var(--effect-height);left:var(--effect-left);opacity:.3;position:absolute;top:var(--effect-top);width:var(--effect-width)}.effect-container.ripple.active:before{animation:ripple var(--effect-duration) linear forwards;border-radius:50%}.large-hex{animation:shape_spin 50s linear 0s infinite forwards;transform-origin:1700px 50px}.med-hex{animation:shape_spin 120s linear 0s infinite reverse;transform-origin:1670px 120px}@keyframes ripple{0%{transform:scale(0)}to{opacity:0;transform:scale(6)}}@keyframes Arrow-float{0%{top:0}to{top:25px}}@keyframes shape_spin{0%{left:0;top:0;transform:rotate(0deg)}to{left:0;top:0;transform:rotate(1turn)}}@keyframes wrong_shake{0%{transform:translateX(10px)}25%{transform:translate(-10px)}50%{transform:translateX(10px)}75%{transform:translateX(-10px)}to{transform:translateX(0)}}@keyframes slide_in_right{0%{opacity:0;transform:translateX(670px)}to{opacity:100%;transform:translateX(0)}}@keyframes slide_in_left{0%{opacity:0;transform:translateX(-670px)}to{opacity:100%;transform:translateX(0)}}@keyframes slide_in_bottom{0%{opacity:0;transform:translateY(130px)}to{opacity:100%;transform:translateY(0)}}@keyframes slide_in_candid_pic{0%{opacity:0;top:570px}to{opacity:70%;top:0}}@keyframes fade_in{0%{opacity:0}to{opacity:100%}}@keyframes leaf_fall{0%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(50vh) rotate(180deg)}to{transform:translateY(100vh) rotate(1turn)}}
/*# sourceMappingURL=main.ce6a76ab.css.map*/