*{box-sizing:border-box}body{font-family:Lato,sans-serif;margin:auto;text-align:left;background-color:#0d0b67;word-wrap:break-word;overflow-wrap:break-word;line-height:1.5;color:#eee;overflow-x:hidden}h1,h2,h3,h4,h5,h6,strong,b{color:#eee}a{color:#3273dc}nav a{margin-right:10px}textarea{width:100%;font-size:16px}input{font-size:16px}content{line-height:1.6}table{width:100%}img{max-width:100%;height:auto}code{padding:2px 5px;background-color:#f2f2f2}pre{padding:1rem}pre>code{all:unset}blockquote{border:1px solid #999;color:#222;padding:2px 0 2px 20px;margin:0;font-style:italic}:target:before{content:"";display:block;height:100px;margin:-100px 0 0}footer{background-color:#15137a;color:#ffffffb3}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}header.header{position:fixed;top:0;left:0;right:0;z-index:1000;background-color:transparent;transition:background-color 2s ease-in-out}header.header.header--scrolled{background-color:#0e0e244d;-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px)}header.header .header__container{width:100%;max-width:100rem;margin:0 auto;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;color:#eee;font-family:DIN Condensed,sans-serif;font-weight:700}header.header .header__logo{flex-shrink:0;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center}header.header .header__logo img{width:100%;height:100%;object-fit:contain;display:block}header.header .header__nav{flex:1;display:flex;align-items:center;gap:2rem;opacity:0;visibility:hidden;transition:opacity .3s ease-in-out,visibility .3s ease-in-out}header.header .header__nav .header__nav-link{font-size:inherit;text-decoration:none;color:inherit;white-space:nowrap;transition:opacity .2s ease-in-out}header.header .header__nav .header__nav-link:hover{opacity:.8}header.header .header__nav.header__nav--visible{opacity:1;visibility:visible}header.header .header__social{display:flex;align-items:center;gap:1rem;opacity:0;visibility:hidden;transition:opacity .3s ease-in-out,visibility .3s ease-in-out}header.header .header__social.header__social--visible{opacity:1;visibility:visible}header.header .header__social .header__social-link{display:flex;align-items:center;justify-content:center;color:inherit;text-decoration:none;transition:transform .2s ease-in-out,opacity .2s ease-in-out;font-size:1.5rem}header.header .header__social .header__social-link:hover{transform:scale(1.1);opacity:.8}header.header .header__menu-button{display:none;background:none;border:none;color:inherit;cursor:pointer;padding:.5rem;font-size:2rem;line-height:1;transition:transform .2s ease-in-out}header.header .header__menu-button:hover{transform:scale(1.1)}header.header .header__menu-button:active{transform:scale(.95)}header.header .header__mobile-overlay{position:fixed;inset:0;width:100vw;height:100vh;background-color:#15137a;z-index:1001;animation:fadeIn .3s ease-in-out}header.header .header__mobile-menu{position:fixed;inset:0;width:100vw;height:100dsh;z-index:1002;display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-end;padding:2rem;overflow:hidden;animation:slideDown .3s ease-in-out}header.header .header__mobile-nav{display:flex;flex-direction:column;align-items:flex-end;gap:1.5rem;width:auto;flex:0 0 auto;margin-bottom:2rem}header.header .header__mobile-nav .header__mobile-link{font-size:2rem;text-decoration:none;color:#eee;text-align:right;width:auto;padding:.75rem 0 .75rem 1rem;transition:opacity .2s ease-in-out}header.header .header__mobile-nav .header__mobile-link:hover{opacity:.7}header.header .header__mobile-social{display:flex;justify-content:flex-end;align-items:center;gap:1.5rem;width:auto;flex:0 0 auto;margin-bottom:1rem}header.header .header__mobile-social .header__mobile-social-link{display:flex;align-items:center;justify-content:center;color:#eee;text-decoration:none;font-size:2.5rem;transition:transform .2s ease-in-out,opacity .2s ease-in-out}header.header .header__mobile-social .header__mobile-social-link:hover{transform:scale(1.15);opacity:.8}header.header .header__close-button{display:flex;align-items:center;justify-content:center;background:none;border:none;color:#5f5ccf;cursor:pointer;padding:.75rem;font-size:2.5rem;line-height:1;transition:transform .2s ease-in-out;flex:0 0 auto;margin-top:1rem}header.header .header__close-button:hover{transform:scale(1.1)}header.header .header__close-button:active{transform:scale(.95)}@media screen and (max-width: 799px){header.header{font-size:1.25rem}header.header .header__container{padding:.5rem 1rem}header.header .header__logo{width:2rem;height:2rem;margin-inline-end:0}header.header .header__nav,header.header .header__social{display:none}header.header .header__menu-button{display:block;margin-left:auto}header.header .header__mobile-overlay{display:block}header.header .header__mobile-menu{display:flex}}@media screen and (min-width: 800px){header.header{font-size:1.5rem}header.header .header__container{padding:1rem 2rem}header.header .header__logo{width:2.5rem;height:2.5rem}header.header .header__nav{display:flex!important;margin-left:auto;margin-right:2rem}header.header .header__social{display:flex!important;flex-shrink:0}header.header .header__menu-button{display:none!important}header.header .header__mobile-overlay,header.header .header__mobile-menu{display:none!important}}.ring{position:fixed;border-radius:50%}.ring1{left:-115px;top:-301px;z-index:1}.ring2{left:-120px;top:729px}.ring3{top:50%;left:80%}button,a{background:none;color:inherit;border:none;font:"DIN Condensed",sans-serif;cursor:pointer;outline:inherit;text-align:inherit;padding:0}button .hidden,a .hidden{display:none}.small-page{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;flex-wrap:nowrap}.small-page main #hero{padding-top:3rem}#landing #hero{width:100vw;min-height:90vh;overflow:hidden;z-index:-1;background-image:url(/img/shapes/shapes.svg);background-position:top-left;background-repeat:repeat;background-size:cover}#landing #hero #hero-content{z-index:2;position:relative;width:100%;height:100%;background-color:#14252a32!important;-webkit-backdrop-filter:50px!important;backdrop-filter:blur(50px)!important}#landing #hero #hero-content .container{z-index:4;padding:6rem 1.5rem .5rem!important}#landing #hero #hero-content .container img{object-fit:contain;object-position:center;width:100%;border-radius:16px 200vh 200vh;margin-bottom:3rem}#landing #hero #hero-content .container .title{font-size:2.5rem;padding-right:1.5rem;position:relative;margin-bottom:1rem;font-family:Poller One,cursive;z-index:6}#landing #hero #hero-content .container .title-container{z-index:5}#landing #hero #hero-content .container .subtitle{font-size:2rem;width:100%;min-width:100px;max-width:600px}#landing #hero #hero-content .container #quick-links{z-index:2;padding-block:2rem;width:100%}#landing #hero #hero-content .container #quick-links .content-container{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;flex-wrap:nowrap;gap:1rem}#landing #hero #hero-content .container #quick-links .quick-link{background:#00000026;border:1px solid rgba(255,255,255,.1);color:#eee;text-decoration:none;border-radius:.75rem;padding:1rem 2rem;width:100%;height:min-content;display:flex;flex-direction:row;align-items:center;justify-content:space-between;flex-wrap:nowrap;font-size:1.5rem;position:relative;transition:all .3s ease;overflow:hidden}#landing #hero #hero-content .container #quick-links .quick-link:before{content:"";position:absolute;top:-150%;left:-150%;width:400%;height:400%;background:linear-gradient(135deg,transparent 0%,transparent 40%,rgba(255,255,255,.05) 50%,transparent 60%,transparent 100%);transition:transform .8s ease;filter:blur(8px)}#landing #hero #hero-content .container #quick-links .quick-link h4{margin:0;padding-right:1rem}#landing #hero #hero-content .container #quick-links .quick-link .icon{font-size:inherit}#landing #hero #hero-content .container #quick-links .quick-link:hover{background:#00000040;border-color:#fff3;transform:translateY(-2px);box-shadow:0 4px 12px #00000026,0 2px 4px #00000014}#landing #hero #hero-content .container #quick-links .quick-link:hover:before{transform:translate(60%,60%)}#landing #hero #hero-content .container #quick-links .quick-link:active{transform:translateY(0);box-shadow:0 2px 6px #0000001a,0 1px 2px #0000000d;transition:all .15s ease}@media screen and (min-width: 0px) and (max-width: 799px){#landing #hero{width:100%;min-height:90vh}#landing #hero #hero-content{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;flex-wrap:nowrap;width:100vw!important;min-height:90vh}#landing #hero #hero-content .container{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;flex-wrap:nowrap;padding-block:3rem}#landing #hero #hero-content .container .title{margin-top:.5rem;margin-bottom:0rem;font-size:1.5rem}#landing #hero #hero-content .container .subtitle{font-size:1rem}#landing #hero #hero-content .container img{max-width:20vh}#landing #hero #hero-content .container .title-container:before{height:8rem;transform:translateY(6rem) rotate(-10deg) scale(1.5)}}@media screen and (min-width: 800px){#landing #hero{height:100%}#landing #hero #hero-content{display:flex;flex-direction:column;align-items:center;justify-content:center;flex-wrap:nowrap;height:90vh;width:100%}#landing #hero #hero-content .container .title{font-size:2rem}#landing #hero #hero-content .container .sub-titles{font-size:1rem}#landing #hero #hero-content .container img{max-width:10rem;object-fit:fill;object-position:center}}#grid{z-index:3;max-width:100ch;padding:0 1rem;margin:8rem auto;gap:3.75rem;background-color:#0d0b67;display:grid}#grid>div,#grid .skills,#grid .resume{z-index:3;color:#eee;text-decoration:none;border-radius:1rem;overflow:hidden;background-position:center;background-size:cover;background-repeat:repeat;filter:drop-shadow(0px 0px 50px rgba(47,210,246,.1))}#grid #plm-module{grid-area:plm;background-image:url(/img/shapes/plm_bg.svg)}#grid #trader-interactive-module{grid-area:trader-interactive;background-image:url(/img/shapes/trader_module_bg.svg)}#grid #smilenow-module{grid-area:smilenow;background-image:url(/img/shapes/smile_now_bg.svg)}#grid #quae-module{grid-area:quae;background-image:url(/img/shapes/quae_module_bg.svg)}#grid #cabal-module{grid-area:cabal;background-image:url(/img/shapes/cabal_labs_bg.svg)}#grid #cabal-module .grid-section{background-color:#3e3e3e40}#grid #bio-module{grid-area:bio;background-image:url(/img/shapes/bio_module_bg.svg)}#grid #bio-module .sub-module{margin-top:1rem}#grid #bio-module .sub-module a{color:#ffffffb3}#grid #projects-module{grid-area:projects;background-image:url(/img/shapes/projct_module_bg.svg)}#grid #projects-module a{text-decoration:none}#grid .row{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;flex-wrap:nowrap;gap:.75rem;height:100%}#grid .row .grid-section{flex:1;height:100%}#grid .grid-section{background-color:#00000053;-webkit-backdrop-filter:blur(50px);backdrop-filter:blur(50px);width:100%;height:100%;padding:1rem;position:relative}@supports not ((-webkit-backdrop-filter: blur(1px)) or (backdrop-filter: blur(1px))){#grid .grid-section{background-color:#000000d9}}#grid .grid-section .header div{display:flex;flex-direction:row;align-items:center;justify-content:space-between;flex-wrap:wrap}#grid .grid-section .header div>a{text-decoration:underline;color:#ffffffb3}#grid .grid-section .header h2{margin:0;font-family:Poller One,cursive}#grid .grid-section .header .headline,#grid .grid-section .header .sub-headline{margin:.25rem 0}#grid .grid-section .footer a{text-decoration:none;color:#eee}@media screen and (max-width: 799px){#grid{grid-template-columns:repeat(1fr,2);grid-template-rows:repeat(auto,10);grid-template-areas:"bio bio" "trader-interactive trader-interactive" "plm plm" "smilenow smilenow" "cabal cabal" "quae quae"}}@media screen and (min-width: 800px){#grid{grid-template-columns:repeat(1fr,2);grid-template-rows:repeat(auto,6);grid-template-areas:"bio bio" "trader-interactive trader-interactive" "plm plm" "smilenow smilenow" "cabal cabal" "quae quae"}}#projects{padding:3rem auto}#projects h1{margin:10rem auto 2rem;text-align:center;font-size:2.5rem;font-weight:400;color:#eee;text-shadow:2px 2px 4px rgba(0,0,0,.5);letter-spacing:.1em;text-transform:uppercase}#projects h1:after{content:"";display:block;width:100%;height:2px;background:linear-gradient(to right,transparent,#5f5ccf,transparent)}#projects #hero{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;flex-wrap:nowrap;background:linear-gradient(to bottom,#41c988,#0d0b67)}#projects #hero h1{font-size:3rem}#projects #hero .buttons{width:min(100%,45rem);padding:2rem 2rem 1rem;display:flex;flex-direction:row;align-items:center;justify-content:space-around;flex-wrap:wrap;gap:1rem}#projects #hero .buttons button{flex:1;min-width:20ch;padding:1rem;text-align:center;border:1px solid #5f5ccf;border-radius:1rem}#projects #hero .buttons button:hover,#projects #hero .buttons button.selected{background-color:#15137a}#projects #hero .filter-btn{border:1px solid #5f5ccf;border-radius:.5rem;padding:.5rem 1rem;margin-bottom:1.5rem;opacity:0}#projects #hero .filter-btn:hover{background-color:#0d0b67}#projects #hero .filter-btn.hidden{opacity:0}#projects #hero .filter-btn.visible{opacity:1;transition:opacity .25s ease-in}#projects .skill-container{display:flex;flex-direction:row;align-items:center;justify-content:center;flex-wrap:wrap;max-width:min(90vw,65rem);margin:3rem auto}#projects .skill-container .tag{display:inline-block;padding:.15rem .5rem;border-radius:.35rem;margin:.1rem;font-size:.9rem;min-width:7ch;text-align:center;border:1.5px solid #084829;color:#41c988;transition:background .2s,color .2s,text-decoration .2s}#projects .projects-container{width:100vw;padding:0 1rem}#projects .project-card{margin:0 auto 3rem;width:clamp(8rem,100%,60rem);display:flex;flex-direction:row;align-items:flex-start;justify-content:center;flex-wrap:wrap;background-color:#3589c54d;border-radius:1.75rem;overflow:hidden;padding:1rem}#projects .project-card .header{display:grid;width:100%}#projects .project-card .header .content{grid-area:content}#projects .project-card .header .content h3,#projects .project-card .header .content h4{margin:0}#projects .project-card .header .content .sub-title{font-style:italic;font-weight:400}#projects .project-card .header .icons{grid-area:icons}#projects .project-card .header .icons a{color:#eee}#projects .project-card .header img{flex:.75;border-radius:1rem;grid-area:logo}#projects .project-card .header .content{flex:1}#projects .project-card .header .content .title{font-size:2rem}#projects .project-card .blocks{padding-inline:1rem;margin-top:2rem}#projects .project-card .blocks .block{flex:.5}#projects .project-card .blocks .block P{flex:1;margin-block:0}@media screen and (max-width: 799px){#projects .project-card .header{grid-template-columns:auto auto auto;grid-template-rows:1fr;justify-items:stretch;align-items:flex-start;grid-template-areas:"logo" "content" "icons";padding-top:2rem;padding:1rem}#projects .project-card .header img{width:5rem}#projects .project-card .header .icons{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;flex-wrap:nowrap;font-size:2rem;gap:2rem;padding-top:2rem}#projects .project-card .header .content{margin-top:1rem;width:100%;justify-self:stretch}}@media screen and (min-width: 800px){#projects .project-card .header{padding:1rem;grid-template-columns:auto 1fr auto;grid-template-rows:1fr;align-items:flex-start;justify-items:stretch;grid-template-areas:"logo content icons"}#projects .project-card .header img{max-width:6rem}#projects .project-card .header .content{flex:1;justify-self:stretch;padding-inline:1rem}#projects .project-card .header .icons{gap:.5rem;font-size:1.5rem;display:flex;flex-direction:row;align-items:center;justify-content:flex-end;flex-wrap:nowrap}#projects .project-card .blocks{padding-bottom:1rem;display:flex;flex-direction:row;align-items:flex-start;justify-content:flex-start;flex-wrap:wrap;gap:1rem}#projects .project-card .blocks img{flex:.5;width:50%}#projects .project-card .blocks img{border-radius:.5rem}}.tag-container{width:100%;flex:1;margin-inline:1rem;display:flex;flex-direction:row;align-items:center;justify-content:flex-start;flex-wrap:wrap}.tag-container .tag{background-color:#0d0b67;border-radius:.25rem;margin:.25rem .25rem 0 0;width:max-content;text-align:center;padding:.25rem}#projects-module{overflow:hidden;position:relative}#projects-module .project-preview{z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;flex-wrap:nowrap;gap:.5rem;overflow:hidden;position:relative;margin:auto}#projects-module .project-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:center;flex-wrap:nowrap;height:100%;width:100%;margin:auto}#projects-module .project-card{margin:auto;text-decoration:none;color:#eee;border-radius:.5rem;display:flex;flex-direction:column;align-items:center;justify-content:center;flex-wrap:nowrap;gap:.5rem;background-color:#103c5b;padding:1rem;width:80%}#projects-module .project-card img,#projects-module .project-card .img{height:8rem;border-radius:1.5rem}#projects-module .project-card .img{opacity:.6}#projects-module .project-card h3,#projects-module .project-card p{padding:0}#projects-module .project-card .tag-container{gap:.5rem;justify-content:center}#project-slider-controls{display:flex;flex-direction:row;align-items:space-between;justify-content:center;flex-wrap:nowrap;width:80%}#project-slider-controls .prev,#project-slider-controls .next{flex:1;font-size:1rem;border-radius:.25rem;display:flex;flex-direction:column;align-items:center;justify-content:center;flex-wrap:nowrap;padding:.5rem;background-color:transparent;color:#000}#project-slider-controls .prev{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;flex-wrap:nowrap}#project-slider-controls .prev:hover{transition:background-color .25s ease-in-out;background:linear-gradient(to right,rgba(0,0,0,.25),transparent)}#project-slider-controls .next{display:flex;flex-direction:row;align-items:center;justify-content:flex-end;flex-wrap:nowrap}#project-slider-controls .next:hover{transition:background-color .25s ease-in-out;background:linear-gradient(to left,rgba(0,0,0,.25),transparent)}html{scroll-padding-top:80px}
