:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.6;font-weight:400;color-scheme:dark;color:var(--primary-font-colour);background-color:var(--secondary-color);background-image:radial-gradient(at 0% 0%,hsla(253,16%,7%,1) 0,transparent 50%),radial-gradient(at 50% 0%,hsla(225,39%,30%,1) 0,transparent 50%),radial-gradient(at 100% 0%,hsla(339,49%,30%,1) 0,transparent 50%);background-attachment:fixed;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{scroll-behavior:smooth}a{font-weight:500;color:#646cff;text-decoration:inherit;transition:color .3s ease}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}}:root{--primary-color: #3b82f6;--secondary-color: #0f172a;--primary-font-colour: #f8fafc;--top-menu-link-default: #94a3b8;--top-menu-link-hover: #3b82f6;--transparent: rgba(15, 23, 42, .75);--glass-border: rgba(255, 255, 255, .1);--z-background: 1;--z-content: 101;--z-menu-base: 1000;--z-menu-dropdown: 1100;color:var(--primary-font-colour)}main{padding-top:6rem}#root{width:100%;max-width:100%;margin:0 auto;text-align:center}.content-container{background:#0f172a99;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);box-shadow:0 8px 32px #0000005e;border-radius:16px;width:90vw;position:relative;padding:2rem;max-width:1200px;max-height:80vh;margin:0 auto;height:auto;min-height:60vh;z-index:var(--z-content);overflow-y:auto}.top-menu-wrapper{position:fixed;top:0;left:0;right:0;height:5rem;z-index:var(--z-menu-base);transform:translateZ(0);border-bottom:1px solid var(--glass-border);transition:background-color .3s ease}.top-menu{background:#0f172acc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);position:relative;min-width:100vw;height:100%;z-index:var(--z-menu-base);display:flex;align-items:center;justify-content:center;gap:3rem;padding:0 2rem}.top-menu-wrapper[data-is-home=true] .top-menu{background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;border-bottom:none}.top-menu-wrapper:not([data-is-home=true]):before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172ad9;z-index:-1;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.top-menu a{text-decoration:none;color:var(--top-menu-link-default);font-weight:500;font-size:1.1rem;transition:all .2s ease;position:relative}.top-menu a:hover{color:var(--top-menu-link-hover);text-shadow:0 0 8px rgba(59,130,246,.5)}.dropdown-container{position:relative;cursor:pointer;height:100%;display:flex;align-items:center}.dropdown-trigger{color:var(--top-menu-link-default);position:relative;z-index:var(--z-menu-base);font-weight:500;font-size:1.1rem;transition:color .2s ease}.dropdown-trigger:hover{color:var(--top-menu-link-hover)}.dropdown-menu{position:absolute;top:100%;left:50%;transform:translate(-50%) translateY(10px);background:#0f172af2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:.5rem;display:flex;flex-direction:column;gap:.5rem;z-index:var(--z-menu-dropdown);min-width:180px;border:1px solid var(--glass-border);border-radius:12px;box-shadow:0 10px 25px #00000080;opacity:0;animation:fadeIn .2s forwards}@keyframes fadeIn{to{opacity:1;transform:translate(-50%) translateY(0)}}.top-menu-wrapper[data-is-home=true] .dropdown-menu{background:#0f172ae6}.dropdown-menu a{text-align:left;padding:.75rem 1rem;z-index:var(--z-menu-dropdown);display:block;color:var(--primary-font-colour);border-radius:8px}.dropdown-menu a:hover{background:#3b82f61a;color:var(--primary-color)}.feed-container{background-color:var(--transparent);position:relative;top:15vh;float:right;margin-right:12vw;width:20vw;max-width:500px;max-height:550px;overflow-y:scroll;display:flex;flex-direction:column;gap:1em;padding:.75em 1.5em .75em .75em}.feed-toggle-button{display:none;position:fixed;bottom:20px;right:20px;padding:12px 24px;background-color:var(--primary-color);color:var(--primary-font-colour);border:none;border-radius:5px;cursor:pointer;z-index:var(--z-menu-dropdown);font-size:1rem;font-weight:500;transition:all .3s ease;box-shadow:0 2px 5px #0003;transform:rotate(270deg)}.feed-toggle-button:hover{background-color:var(--top-menu-link-hover);transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.feed-toggle-button:active{transform:translateY(0);box-shadow:0 2px 4px #0003}.feed-item{text-align:right}.feed-item-header{font-size:.8rem;color:var(--primary-font-colour)}.feed-item-content{font-size:1rem;color:var(--primary-font-colour)}.feed-item-author{font-size:.8rem;font-style:italic;color:var(--primary-font-colour)}.feed-container::-webkit-scrollbar{width:8px}@media(max-width:768px){.feed-container{position:fixed;top:auto;bottom:80px;right:20px;float:none;margin:0;width:50vw;max-height:60vh;transition:transform .3s ease-in-out,opacity .3s ease-in-out;background-color:var(--secondary-color);border:1px solid var(--primary-font-colour);border-radius:5px;box-shadow:0 0 10px #0003}.feed-container.hidden{transform:translate(100%);width:50vw;opacity:0;pointer-events:none}.feed-container.visible{transform:translate(0);width:50vw;opacity:1}.feed-toggle-button{display:block;position:fixed;bottom:200px;right:-2em;transform:rotate(270deg)}.feed-toggle-button:active,.feed-toggle-button:hover{transform:rotate(270deg)}}@media(max-width:480px){.feed-toggle-button{padding:10px 20px;font-size:.9rem;position:fixed;bottom:200px;right:-2em;transform:rotate(270deg)}.feed-container{width:90vw;max-height:70vh}}.landing-container{position:absolute;top:0;left:0;width:100vw;height:100vh;background-image:url(/landing_main.png);background-position:center;background-repeat:no-repeat;background-size:cover;box-sizing:border-box}.landing-container:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#0f172a66,#0f172a1a)}.header-container{position:absolute;top:35vh;left:10vw;z-index:10;animation:slideUpFade 1s ease-out forwards;opacity:0}@keyframes slideUpFade{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.header-title{font-size:6rem;font-weight:700;color:var(--primary-font-colour);text-shadow:2px 2px 4px rgba(0,0,0,.5);margin-bottom:0;letter-spacing:-2px}.header-subtitle{font-size:2.5rem;font-weight:300;color:var(--primary-color);margin-top:-1rem;text-align:right;text-shadow:1px 1px 2px rgba(0,0,0,.5)}@media(max-width:768px){.header-container{top:30vh;left:5vw}.header-title{font-size:4rem}.header-subtitle{font-size:1.8rem;margin-top:-.5rem}}@media(max-width:480px){.landing-container{background-position:65% center;display:flex;flex-direction:column;justify-content:center;align-items:center}.header-container{position:relative;top:auto;left:auto;width:90vw;text-align:center}.header-title{font-size:3.5rem;text-align:center}.header-subtitle{font-size:1.5rem;margin-top:0;text-align:center}}@media(max-width:320px){.header-title{font-size:2.5rem}.header-subtitle{font-size:1.2rem}}@media(max-height:480px)and (orientation:landscape){.header-container{top:15vh}.header-title{font-size:2.5rem}.header-subtitle{font-size:1.2rem;margin-top:0}}body{overflow:hidden}.project-menu{display:flex;justify-content:center;gap:1rem;margin-bottom:3rem;flex-wrap:wrap}.project-content-paragraph{margin:.5rem 0}.project-link{padding:.75rem 1.5rem;border:1px solid var(--glass-border);background:#ffffff0d;cursor:pointer;font-size:1rem;color:var(--top-menu-link-default);border-radius:50px;transition:all .3s ease;font-weight:500}.project-link:hover{background:#ffffff1a;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.project-link.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color);box-shadow:0 4px 12px #3b82f666}.project-content{animation:fadeIn .3s ease}.screenshot-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-top:2rem}.screenshot{width:100%;height:200px;object-fit:cover;cursor:pointer;border-radius:12px;transition:all .3s ease;border:1px solid var(--glass-border);background:#0003}.screenshot:hover{transform:scale(1.03);box-shadow:0 8px 20px #0000004d;border-color:var(--primary-color)}.project-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:100;cursor:pointer}.modal-content{max-width:90%;max-height:90vh}.modal-content img,.modal-content video{max-width:100%;max-height:80vh;object-fit:contain}.modal-text{color:#fff;margin-top:1rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.project-menu{flex-direction:column;align-items:stretch}.project-link{text-align:center}}.technologies{display:flex;gap:.75rem;flex-wrap:wrap;margin:1.5rem 0}.tech-tag{background:#3b82f626;color:#93c5fd;padding:.4rem 1rem;border-radius:8px;font-size:.85rem;font-weight:500;border:1px solid rgba(59,130,246,.3);transition:all .2s ease}.tech-tag:hover{background:#3b82f640;transform:translateY(-1px)}.project-links{display:flex;gap:1rem;margin:2rem 0}.project-links a{color:#fff;text-decoration:none;padding:.75rem 1.5rem;border-radius:8px;background:#ffffff1a;transition:all .3s ease;font-weight:500;display:inline-flex;align-items:center;gap:.5rem}.project-links a:hover{background:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.certification-menu{display:flex;flex-direction:column;gap:2rem;padding:1rem;max-height:70vh;overflow-y:auto}.certification-category{display:flex;flex-direction:column;gap:1rem}.certification-category h3{color:var(--primary-font-colour);margin:0;padding-bottom:.5rem;border-bottom:1px solid var(--primary-font-colour)}.certification-list{display:flex;flex-direction:column;gap:.5rem}.certification-item{text-align:left;padding:.75rem 1rem;background:transparent;border:1px solid var(--primary-font-colour);border-radius:4px;color:var(--primary-font-colour);cursor:pointer;transition:all .3s ease}.certification-item:hover{background:var(--primary-color);color:#fff}.certification-item.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.certification-menu::-webkit-scrollbar{width:8px}.certification-menu::-webkit-scrollbar-track{background:transparent}.certification-menu::-webkit-scrollbar-thumb{background:var(--primary-font-colour);border-radius:4px}@media(max-width:768px){.certification-menu{max-height:50vh;padding:.5rem}.certification-item{padding:.5rem .75rem}}.certifications-container{display:flex;gap:2rem;width:100%;height:100%}.certification-menu{width:300px;flex-shrink:0}.certification-details{flex-grow:1;padding:1rem}.certification-details img{max-width:100%;height:auto}.certification-item{width:100%;border:0}.certification-menu::-webkit-scrollbar{width:4px}@media(max-width:768px){.certifications-container{flex-direction:column}.certification-menu{width:100%;margin-bottom:2rem}}#skillsContainer{display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:2rem;max-width:1200px;margin:0 auto;gap:2rem}#skillsContent{background-color:transparent;padding:2rem;border-radius:8px;width:60vw}.skillsHR{border:0;height:1px;background:var(--primary-font-colour);margin:1rem 0}#skillsMenu{display:flex;gap:1rem;padding:0 2em 2em;justify-content:flex-start;max-height:40vh;overflow-y:auto;overflow-x:hidden;margin-top:2em}#skillsMenu:before{content:"";display:block;height:0}.skillsMenuSelection{width:64px;height:64px;cursor:pointer;transition:all .3s ease;filter:grayscale(100%);opacity:.6}.skillsMenuSelection:hover{transform:scale(1.15);filter:grayscale(0%);opacity:1;filter:drop-shadow(0 0 8px rgba(255,255,255,.5))}.skillsMenuSelection.active{filter:grayscale(0%);opacity:1;transform:scale(1.15);filter:drop-shadow(0 0 12px rgba(59,130,246,.6))}.content{color:var(--primary-font-colour);line-height:1.6;margin-bottom:1rem}#skillsMenu::-webkit-scrollbar{width:8px}#skillsMenu::-webkit-scrollbar-thumb{background-color:var(--primary-font-colour)}@media(min-width:768px){#skillsContainer{flex-direction:row;align-items:flex-start}#skillsMenu{flex-direction:column;order:-1}}@media(max-width:768px){#skillsContainer{flex-direction:column-reverse;padding:1rem;gap:1rem}#skillsContent{width:90vw;padding:1rem}#skillsMenu{width:90vw;max-height:200px;padding:1rem;margin-top:1rem;justify-content:center;flex-wrap:wrap;gap:.5rem}.skillsMenuSelection{width:48px;height:48px}h3{font-size:1.2em}.content{font-size:.9em;line-height:1.4}}@media(max-width:420px){#skillsContent,#skillsMenu{width:95vw;padding:.5rem}.skillsMenuSelection{width:40px;height:40px}}#contactInfoFlexbox{display:flex;flex-direction:column;gap:2rem;padding:2rem;max-width:800px;margin:0 auto}.form-label{text-align:left}.contact-links{display:flex;flex-direction:column;gap:1rem}.contact-links div{display:flex;align-items:center;gap:1rem}.icons{width:24px;height:24px}.link{color:var(--primary-font-colour);text-decoration:none;transition:color .3s ease}.link:hover{color:var(--top-menu-link-hover)}#contactFormWrapper{width:100%;display:none}#contactForm{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}input,textarea{padding:.75rem;border:1px solid var(--glass-border);border-radius:8px;background:#ffffff0d;color:var(--primary-font-colour);transition:all .3s ease;font-family:inherit}input:focus,textarea:focus{outline:none;border-color:var(--primary-color);background:#ffffff1a;box-shadow:0 0 0 2px #3b82f633}textarea{min-height:150px;resize:vertical}button[type=submit]{padding:.75rem 2rem;background:var(--primary-color);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;align-self:flex-start;font-weight:500;box-shadow:0 4px 6px #0000001a}button[type=submit]:hover{background:var(--primary-hover, #2563eb);transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}@media(min-width:768px){#contactInfoFlexbox{flex-direction:row;align-items:flex-start}.contact-links{min-width:300px}}.privacy-policy{max-width:800px;margin:2rem auto;padding:0 1rem}.privacy-policy h1{color:var(--primary-font-colour);margin-bottom:.5rem}.privacy-policy section{margin:2rem 0}.privacy-policy h2{color:var(--primary-font-colour);font-size:1.5rem;margin-bottom:1rem}.privacy-policy p{line-height:1.6;color:var(--secondary-font-colour)}@media(max-width:768px){.privacy-policy{margin:1rem auto}}footer{position:fixed;background-color:var(--secondary-color);bottom:0;left:0;width:100%;padding:1rem;text-align:center;z-index:100}#footerText{margin:0;color:var(--primary-font-colour)}.footer-link{color:var(--primary-font-colour);text-decoration:none;transition:color .3s ease}.footer-link:hover{color:var(--top-menu-link-hover)}
