.hello-section{background-color:var(--transparent-background);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(2px);border-radius:12px;padding:2rem;text-align:center}.hello-button-wrapper{margin:1rem 0;display:flex;gap:1rem;justify-content:center}.hello-logo-wrapper{display:flex;align-items:center;margin-bottom:2rem}.logo{display:flex;align-items:center}.logo-text{display:flex;flex-shrink:0}.logo-tags{display:flex;flex-shrink:0;margin-left:auto}.hello-section_body{display:flex;align-items:baseline;justify-content:center;gap:.5rem}.hello-section_body-1{color:var(--tertiary-yellow)}.hello-link-wrapper{margin:1rem}.hello-link{display:inline-flex;align-items:center;gap:.4rem;color:var(--tertiary-red);text-decoration:none;border:none;background:transparent;cursor:pointer;transition:color .2s ease,transform .2s ease}.hello-link:hover{color:var(--secondary-orange)}.hello-link span{display:inline-block;transform:translateY(1px);transition:transform .2s ease}.hello-link:hover span{transform:translate(2px,-2px)}.key-facts{display:flex;gap:1.5rem;justify-content:center;align-items:center;margin:2rem 0;flex-wrap:wrap}.key-fact-item{padding:0rem 1rem;border-left:2px dashed var(--secondary-blue)}.key-fact-item p{margin:0;border-radius:8px;transition:all .3s ease}.key-fact-item:hover{border-left-color:var(--tertiary-yellow)}.key-fact-item:hover p{transform:translate(2px)}.torus{border-radius:9px;max-width:100%;margin:1rem 0;z-index:-100}.torus-wrapper{z-index:-100;top:0;left:0;position:fixed;width:100vw;height:100vh}.hello-cube_wrapper{display:flex;justify-content:center;align-items:center;margin-top:2rem}.cube-container{position:relative;display:flex;justify-content:center;align-items:center}.cube{margin:4rem 0;width:150px;height:150px;transform-style:preserve-3d;animation:spin 15s infinite linear;z-index:0}.face{position:absolute;width:150px;height:150px;border:1px dashed var(--primary-black);box-sizing:border-box}.front{transform:rotateX(0) rotateY(0) translateZ(75px)}.back{transform:rotateX(0) rotateY(180deg) translateZ(75px)}.left{transform:rotateX(0) rotateY(-90deg) translateZ(75px)}.right{transform:rotateX(0) rotateY(90deg) translateZ(75px)}.top{transform:rotateX(-90deg) rotateY(0) translateZ(75px)}.bottom{transform:rotateX(90deg) rotateY(0) translateZ(75px)}@keyframes spin{0%{transform:rotateX(0) rotateY(0)}to{transform:rotateX(360deg) rotateY(360deg)}}@media screen and (max-width: 1200px){.logo-tags{display:none}.hello-logo-wrapper{justify-content:center}}@media screen and (max-width: 768px){.hello-logo-wrapper{justify-content:flex-start}.hello-section{text-align:left}.hello-section_body{flex-direction:column}.hello-link-wrapper{display:none}.key-facts{display:flex;flex-direction:column;align-items:flex-start;gap:1rem}.key-fact-item{padding-left:.8rem;border-left:2px dashed var(--secondary-blue);width:100%}.key-fact-item:hover{border-left-color:var(--secondary-blue)}.key-fact-item:hover p{transform:none}.key-facts p{text-align:left;padding:.6rem 1rem}.torus-wrapper{display:none}}.about-section{backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(2px);border-radius:12px;background-color:var(--transparent-background)}.about-section_fact-wrapper{display:flex;justify-content:center;flex-direction:column;gap:2rem;margin:0 auto}.about-wave_wrapper{display:flex;justify-content:center;width:200px;height:200px;align-self:center}.wave{display:flex;flex-direction:column;align-items:center}.element{position:absolute;width:calc(var(--i) * 50px);aspect-ratio:1;border-radius:100vh;border:2px dashed var(--primary-black);animation:wave-move 5s ease-in-out calc(var(--i) * .2s) infinite}@keyframes wave-move{0%,to{transform:rotateX(70deg) translateZ(-50px) translateY(0)}50%{transform:rotateX(70deg) translateZ(50px) translateY(100px)}}.bento-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.bento-grid-bespoke{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr;gap:1rem;margin:2rem 0;grid-template-areas:"skills services tools" "skills services tools"}.about-card-body+.about-card-body{margin-top:1rem}.bento-item-bespoke{background-color:var(--transparent-background);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(2px);border-radius:18px;padding:2rem;display:flex;flex-direction:column;align-items:flex-start;min-height:260px}.bento-services{grid-area:services}.bento-tools{grid-area:tools}.bento-skills{grid-area:skills}.bento-title{color:var(--tertiary-yellow);margin-bottom:.5rem}.bento-list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.5rem}.bento-list-item{color:var(--primary-black);background:#ffffff1f;border-radius:8px;padding:.25rem .75rem;margin-bottom:.2rem}.about-top-grid{display:grid;grid-template-columns:2.5fr 1fr;gap:1rem;margin-top:1.5rem}.about-card{background-color:var(--transparent-background);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(2px);border-radius:18px;padding:2rem;box-shadow:0 2px 16px #0000000a;display:flex;flex-direction:column;justify-content:center}.about-card-me{grid-column:1/ 2}.about-card-side{grid-column:2 / 3}.about-card-title{color:var(--tertiary-green)}.about-card-body{color:var(--primary-black)}.about-card-span{color:var(--tertiary-red);font-weight:700}.about-card-span2{color:var(--tertiary-yellow);font-weight:700}@media (max-width: 900px){.bento-grid-bespoke{grid-template-columns:1fr;grid-template-rows:auto;grid-template-areas:"services" "tools" "skills"}.about-top-grid{grid-template-columns:1fr;gap:1rem}.about-card-me,.about-card-side{grid-column:auto}.bento-title{margin-bottom:1rem}.element{width:calc(var(--i) * 25px)}}@media (max-width: 768px){.about-card-side{display:none}.about-top-grid{grid-template-columns:1fr}}.section-divider{margin-top:1rem;display:flex;align-items:flex-start}.section-divider_description>span{font-weight:700}.section-divider_description-wrapper{display:flex;flex-direction:column;align-items:baseline;width:100%;margin-left:1rem}.section-divider-text-wrapper{display:flex;width:100%}.section-divider_number{margin-left:auto}.work-section{backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(2px);border-radius:12px;background-color:#8b8b8b1a;margin-top:2rem;border:2px dashed var(--tertiary-yellow)}.work-section_card-wrapper{display:grid;grid-template-columns:1fr;gap:2rem;width:100%;padding:2rem;margin:0 auto}@media (min-width: 768px){.work-section_card-wrapper{grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:1fr}}.floating-button_wrapper{display:flex;flex-direction:column;gap:1rem;align-items:flex-start;padding:1rem;position:fixed;bottom:0rem}.project-card{position:relative;width:100%;min-height:450px;height:100%;background-color:#111;overflow:hidden;border:1px solid rgba(255,255,255,.1);transition:transform .3s ease;border-radius:8px;display:flex;flex-direction:column;cursor:pointer}.project-card:hover{transform:translateY(-4px)}.project-card--active{transform:translateY(-4px);border-color:var(--tertiary-yellow);box-shadow:0 8px 32px #ffde2233}.project-card_content{position:relative;z-index:2;height:100%;padding:1.5rem;display:flex;flex-direction:column;color:#fff}@media (min-width: 640px){.project-card_content{padding:1.5rem}}.project-card_top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.project-card_category{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;padding:.5rem .75rem;background-color:#ffffff1a;border-radius:2px}.project-card_title{margin-top:auto;width:100%}.project-card_description{max-width:100%;color:var(--tertiary-green)}.project-card_overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to bottom,#111111b3,#111111e6);z-index:1}.project-card_image{width:100%;height:100%;object-fit:cover;opacity:.6;mix-blend-mode:screen;filter:contrast(1.1) grayscale(.4);transition:transform .3s ease}.project-card:hover .project-card_image{transform:scale(1.05)}.project-card:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(rgba(255,255,255,.1) 1px,transparent 1px);background-size:4px 4px;opacity:.15;z-index:2;pointer-events:none}.project-card_click-hint{margin-top:auto;opacity:0;transition:opacity .3s ease;color:var(--tertiary-yellow);font-style:italic}.project-card:hover .project-card_click-hint{opacity:1}.play-iframe-section{margin:2rem 0;width:100%;border-radius:12px}.play-iframe-wrapper{position:relative;width:100%;height:100vh;min-height:500px;max-height:700px;border-radius:12px;overflow:hidden}.play-iframe{width:100%;height:100%;border:none;overflow:hidden;pointer-events:none;border-radius:12px}.play-iframe-wrapper:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,transparent 0%,rgba(255,222,34,.05) 25%,transparent 50%,rgba(255,222,34,.05) 75%,transparent 100%);pointer-events:none;z-index:1}@media (max-width: 768px){.play-iframe-wrapper{height:55vh;min-height:400px;max-height:500px}}@media (max-width: 480px){.play-iframe-wrapper{height:50vh;min-height:350px;max-height:400px;margin:1rem 0}}.contact-section{display:flex;gap:5rem;flex-direction:column;background-color:#8b8b8b1a}.contact-section{margin-top:2rem;background-color:var(--transparent-background);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(2px);border-radius:12px;padding:2rem;text-align:center;scroll-margin-top:2rem;will-change:transform}.contact-form{display:flex;flex-direction:column;width:100%;max-width:660px;margin:0 auto;position:relative}.contact-form_text-wrapper{display:flex;flex-direction:column;gap:.5rem;width:100%;margin-bottom:2rem}.contact-form_text-wrapper h1,.contact-form_text-wrapper p{transition:color .3s ease}.contact-form_header{color:var(--secondary-orange)}.contact-form label{display:flex;flex-direction:column;gap:.5rem;text-align:left;margin-bottom:8px;transition:all .3s ease;position:relative}.error-email-span{color:var(--tertiary-green)}.contact-form_name{margin-bottom:2rem}.contact-form input[type=text],.contact-form input[type=email],.contact-form textarea{background-color:var(--pure-white);color:var(--primary-black);width:100%;padding:1rem;margin-bottom:.75rem;border:2px dashed var(--primary-black);box-shadow:none;border-radius:9px;font-size:1.5rem;transition:all .3s ease;transform:translateZ(0)}.contact-form textarea{margin-bottom:0}.contact-form textarea{width:100%;height:20rem;resize:none;color:var(--primary-black);font-family:NeueMontreal;font-size:1.5rem}.contact-form input[type=text]:focus,.contact-form input[type=email]:focus,.contact-form textarea:focus{transform:translateY(-2px) translateZ(0);box-shadow:0 4px 12px #0000001a}.contact-form input[type=submit]{margin-top:1rem;font-family:NeueBit,sans-serif;align-self:flex-start;font-weight:700;font-size:2rem;color:var(--primary-white);padding:1rem 1.5rem;cursor:pointer;border-radius:14px;border:none;transition:all .3s ease;transform:translateZ(0);position:relative;overflow:hidden;text-decoration:none}.contact-form input[type=submit]:hover{text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:4px}.contact-form input[type=submit]:focus{border:solid 2px var(--secondary-blue);box-shadow:none}.contact-form input[type=submit]:focus:not(:focus-visible){border:none;box-shadow:none}.contact-form_content{display:flex;flex-direction:column;gap:1.5rem}.contact-form_field{display:flex;flex-direction:column}.contact-form_field input,.contact-form_field textarea{opacity:.6;cursor:not-allowed}.contact-form_email-link{margin-top:1rem;text-align:center}.email-link{display:inline-block;color:var(--primary-black);text-decoration:none;font-weight:700;font-size:1.5rem;padding:1rem 2rem;background-color:var(--transparent-background);border:2px dashed var(--primary-black);border-radius:12px;transition:all .3s ease;cursor:pointer}.email-link:hover{box-shadow:var(--shadow-mid);transform:translateY(-2px);background-color:var(--secondary-orange);color:var(--pure-white);border-color:var(--secondary-orange)}.email-link:focus{border:solid 2px var(--secondary-blue);box-shadow:none;outline:none}.contact-form input[type=text]:-webkit-autofill,.contact-form input[type=email]:-webkit-autofill,.contact-form input[type=text]:-webkit-autofill:hover,.contact-form input[type=email]:-webkit-autofill:hover,.contact-form input[type=text]:-webkit-autofill:focus,.contact-form input[type=email]:-webkit-autofill:focus,.contact-form input[type=text]:-webkit-autofill:active,.contact-form input[type=email]:-webkit-autofill:active{-webkit-box-shadow:0 0 0 30px var(--transparent-background) inset!important;-webkit-text-fill-color:var(--primary-black)!important;background-color:var(--transparent-background)!important;border:2px dashed var(--primary-black)!important;transition:background-color 5000s ease-in-out 0s}.contact-form input[type=text]:-moz-autofill,.contact-form input[type=email]:-moz-autofill{background-color:var(--transparent-background)!important;color:var(--primary-black)!important;border:2px dashed var(--primary-black)!important}.contact-form input[type=text]:autofill,.contact-form input[type=email]:autofill{background-color:var(--transparent-background)!important;color:var(--primary-black)!important;border:2px dashed var(--primary-black)!important}@media screen and (max-width: 1200px){.contact-form{width:100%}.contact-form_text-wrapper{margin-bottom:.75rem;width:100%}.contact-form input[type=text],.contact-form input[type=email],.contact-form textarea{font-size:1rem}.email-link{font-size:1rem;padding:.75rem 1.5rem}}.notification-wrapper{position:relative;display:flex;align-items:center;gap:1rem}.notification-text{display:flex;flex-direction:column;align-items:center}.success-message,.error-message{position:fixed;top:24px;left:50%;transform:translate(-50%);color:#fff;padding:1rem 1.5rem;border-radius:12px;animation:slideDown .3s ease-out forwards;z-index:1000;text-align:center;min-width:300px;display:flex;align-items:center;justify-content:space-between;gap:1rem}.error-message,.success-message{background-color:var(--transparent-background);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(2px)}.success-message.closing,.error-message.closing{animation:slideUp .3s ease-out forwards}.notification-close{background:transparent;border:none;color:#fff;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;opacity:.8;transition:opacity .2s;font-size:1.2rem}@keyframes slideDown{0%{opacity:0;transform:translate(-50%,-100%)}to{opacity:1;transform:translate(-50%)}}@keyframes slideUp{0%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,-100%)}}footer{display:flex;justify-content:space-between;align-items:center;margin:1rem auto}.footer_links-container{width:100%;display:flex;justify-content:center;margin-left:0 auto}.footer_links-container a+a{margin-left:2rem}.footer_links-container a{text-decoration:none}.footer_links-container a:hover{text-decoration:underline}@media screen and (max-width: 768px){.footer_links-container{text-decoration:underline}}@font-face{font-family:NeueMontreal;src:url(/assets/PPNeueMontreal-Bold-B59Kvoi-.woff);font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:NeueMontreal;src:url(/assets/PPNeueMontreal-Medium-BD76cbgA.woff);font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:NeueBit;src:url(/assets/PPNeueBit-Bold-DLXBbhAT.woff);font-weight:700;font-style:normal;font-display:swap}:root{--font: "NeueMontreal", sans-serif;--primary-black: #e2e2e2;--transparent-background: rgba(139, 139, 139, .1);--primary-white: #171717;--pure-white: #000000;--primary-grey: #000000;--secondary-blue: #063ffa;--tertiary-yellow: #ffde22;--tertiary-red: #ca1111;--tertiary-purple: #9610fe;--tertiary-green: #58da4d}html{box-sizing:border-box;font-size:16px}*,*:before,*:after{box-sizing:inherit}body,h1,h2,h3,h4,h5,h6,p,ol,ul{margin:0;padding:0;font-weight:400}ul,ol{list-style:square}a{text-decoration:none;color:inherit}a{font-weight:500;color:inherit;text-decoration:inherit}a:hover{color:inherit}img{max-width:100%;height:auto}body{position:relative;font-family:var(--font),sans-serif;font-weight:400;font-size:16px;color:var(--primary-black);background-color:var(--primary-grey);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;width:100%}html{scroll-behavior:smooth}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}html{scroll-behavior:auto}}.modal-overlay,.modal-content,.project-card,.bento-item-bespoke,.about-card{will-change:transform,opacity}.modal-overlay:not(.animating),.modal-content:not(.animating),.project-card:not(.animating),.bento-item-bespoke:not(.animating),.about-card:not(.animating){will-change:auto}.text-huge{font-size:5rem;font-style:normal;font-weight:700;line-height:100%;font-family:NeueBit}.text-display{font-size:4rem;font-style:normal;font-weight:700;line-height:100%}.text-header-large{font-size:3rem;font-style:normal;font-weight:400;line-height:120%}.text-header-large-variant{font-family:NeueBit;font-size:4rem;font-style:normal;font-weight:400;line-height:100%}.text-title-bold{font-size:1.5rem;font-style:normal;font-weight:700;line-height:150%}.text-header{font-size:2rem;font-style:normal;font-weight:400;line-height:130%}.text-header-variant{font-family:NeueBit;font-size:2.5rem;font-style:normal;font-weight:400;line-height:130%}.text-header-small{font-size:1.5rem;font-style:normal;line-height:normal}.text-title{font-size:1.5rem;font-style:normal;font-weight:400;line-height:130%}.text-note{font-size:1.25rem;font-style:normal;font-weight:400;line-height:130%}.text-note-bold{font-size:1.25rem;font-style:normal;font-weight:700;line-height:150%}.text-body-large{font-size:1.5rem;font-style:normal;font-weight:400;line-height:150%}.text-body-large-variant{font-size:2rem;font-style:normal;font-weight:400;font-family:NeueBit}.text-body{font-size:1rem;font-style:normal;font-weight:400;line-height:150%}.text-body-bold{font-size:1rem;font-style:normal;font-weight:700;line-height:150%}body{width:100%;margin:1rem auto}@media screen and (max-width: 768px){#contact,#work,#play{display:none}.text-huge{font-size:3.5rem}.text-display,.text-header-large{font-size:2rem}.text-body-large{font-size:1.25rem}.text-header-large-variant{font-size:2.5rem}.text-header{font-size:1.25rem}.text-header-small{font-size:1rem}.text-title-bold,.text-title{font-size:1.25rem}.text-note,.text-note-bold{font-size:1rem}.text-body-large-varant{font-size:1.5rem}.text-header-large-variant{font-size:3rem}.text-header{font-size:1.5rem}.text-header-small{font-size:1.25rem}.text-note-bold{font-size:1rem}}.content-container{margin:0 auto;max-width:1400px;width:100%;padding-left:1.5rem;padding-right:1.5rem}
