.hello-section{background-color:var(--transparent-background);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:12px;border:1px solid transparent;padding:2rem;margin-top: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;justify-content:space-between;margin-bottom:2rem;gap:1rem}.hello-topbar{display:flex;align-items:center;gap:1rem}.logo{display:flex;align-items:center}.logo-text{display:flex;flex-shrink:0}.logo-tags{display:flex;flex-shrink:0;margin-left:auto}.theme-toggle{font-family:NeueMontreal,sans-serif;display:inline-flex;align-items:center;gap:.7rem;border:none;padding:0;color:var(--primary-black);box-shadow:none;cursor:pointer;background:transparent;transition:transform .25s ease,opacity .25s ease}.theme-toggle:hover{transform:translateY(-2px);opacity:.9}.theme-toggle_label{font-size:.85rem;line-height:1;text-transform:lowercase}.theme-toggle_track{display:inline-flex;align-items:center;width:3rem;height:1.8rem;padding:.15rem;border:2px dashed var(--border-color);border-radius:999px;background:color-mix(in srgb,var(--primary-black) 8%,transparent);transition:border-color .25s ease,background-color .25s ease}.theme-toggle_icon{width:1.1rem;height:1.1rem;border-radius:999px;background:var(--primary-black);transition:transform .25s ease,background-color .25s ease}.theme-toggle[aria-checked=true] .theme-toggle_icon{transform:translate(1.2rem)}.theme-toggle[aria-checked=false] .theme-toggle_icon{background:color-mix(in srgb,var(--primary-black) 28%,var(--surface-strong))}.theme-toggle:hover .theme-toggle_track{border-color:color-mix(in srgb,var(--primary-black) 24%,var(--border-color))}.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)}.hello-skull_wrapper{display:flex;justify-content:center;align-items:center;margin-top:2rem;width:100%}.hello-skull{margin:0;padding:1rem 1.25rem;color:var(--primary-black);background:transparent;font-family:SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.72rem;line-height:1.05;letter-spacing:.04em;white-space:pre;text-align:left;opacity:.86;-webkit-user-select:none;user-select:none}@media screen and (max-width: 1200px){.logo-tags{display:none}}@media screen and (max-width: 768px){.hello-logo-wrapper{justify-content:space-between}.hello-topbar{width:100%;justify-content:space-between}.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}.hello-skull{font-size:.5rem;line-height:1;letter-spacing:.02em;padding:.5rem 0}}.about-section{border-radius:12px;background-color:var(--transparent-background);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.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(10px);-webkit-backdrop-filter:blur(10px);border:1px solid transparent;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:var(--surface-soft);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(10px);-webkit-backdrop-filter:blur(10px);border-radius:18px;border:1px solid transparent;padding:2rem;box-shadow:none;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}.testimonial-section{margin:0 0 2rem}.testimonial-section_header{display:flex;justify-content:space-between;align-items:end;gap:1rem;margin-bottom:1.25rem}.testimonial-section_kicker{color:var(--secondary-blue);text-transform:uppercase;letter-spacing:.08em}.testimonial-section_title{max-width:32rem;color:var(--primary-black);text-align:right}.testimonial-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;align-items:stretch;margin-top:1rem}.testimonial-card{background-color:var(--transparent-background);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:18px;border:2px dashed var(--border-color);padding:1.6rem;display:flex;flex-direction:column;justify-content:space-between;gap:1rem;min-height:18rem;height:100%;position:relative}.testimonial-card_mark{line-height:.8;margin-bottom:.25rem}.testimonial-card_text{color:var(--primary-black);flex:1;max-width:38ch}.testimonial-card_meta{display:flex;flex-direction:column;gap:.35rem;padding-top:.5rem;border-top:1px dashed var(--border-color)}.testimonial-card_name{color:var(--primary-black);font-weight:700}.testimonial-card_role{color:color-mix(in srgb,var(--primary-black) 72%,transparent)}.testimonial-card_role span{color:var(--secondary-blue)}@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)}.testimonial-section_header{flex-direction:column;align-items:flex-start}.testimonial-section_title{text-align:left}.testimonial-grid{grid-template-columns:1fr}}@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{border-radius:12px;background-color:var(--transparent-background);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);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:var(--surface-strong);overflow:hidden;border:1px solid var(--border-color);transition:transform .3s ease,border-color .3s ease,background-color .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:none}.project-card_content{position:relative;z-index:2;height:100%;padding:1.5rem;display:flex;flex-direction:column;color:var(--primary-black)}@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:var(--surface-muted);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:transparent;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(var(--border-color) 1px,transparent 1px);background-size:4px 4px;opacity:.24;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}.contact-section{display:flex;gap:5rem;flex-direction:column;background-color:var(--transparent-background)}.contact-section{margin-top:2rem;background-color:var(--transparent-background);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:12px;border:1px solid transparent;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(--tertiary-yellow)}.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(--input-background);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:none}.contact-form_submit{margin-top:1rem;font-family:NeueBit,sans-serif;align-self:flex-start;color:var(--tertiary-red);padding:0;cursor:pointer;border-radius:0;border:none;background-color:transparent;display:inline-flex;align-items:center;gap:.4rem;transition:color .2s ease,transform .2s ease;transform:translateZ(0);text-decoration:none}.contact-form_submit:hover{color:var(--secondary-orange)}.contact-form_submit span:last-child{display:inline-block;transform:translateY(1px);transition:transform .2s ease}.contact-form_submit:hover span:last-child{transform:translate(2px,-2px)}.contact-form_submit:focus{outline:2px solid var(--secondary-blue);outline-offset:4px}.contact-form_submit:focus:not(:focus-visible){outline: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:none;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:var(--notification-foreground);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:var(--notification-foreground);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: #171717;--primary-white: #f7f5ef;--pure-white: #ffffff;--primary-grey: #f3efe4;--transparent-background: rgba(255, 255, 255, .62);--secondary-orange: #f26a1b;--secondary-blue: #063ffa;--tertiary-yellow: #e6a800;--tertiary-red: #ca1111;--tertiary-purple: #9610fe;--tertiary-green: #2aa61f;--surface-strong: #fffdfa;--surface-soft: rgba(23, 23, 23, .06);--surface-muted: rgba(23, 23, 23, .08);--surface-overlay: rgba(243, 239, 228, .82);--surface-overlay-start: rgba(255, 253, 250, .7);--surface-overlay-end: rgba(243, 239, 228, .92);--border-color: rgba(23, 23, 23, .12);--input-background: #fffdfa;--notification-foreground: #171717;--shadow-soft: none;--panel-border: rgba(23, 23, 23, .08);--panel-texture: none}:root[data-theme=dark]{--primary-black: #efefec;--primary-white: #171717;--pure-white: #050505;--primary-grey: #030303;--transparent-background: rgba(8, 8, 8, .34);--secondary-orange: #ff4636;--secondary-blue: #1e4dff;--tertiary-yellow: #ffd91a;--tertiary-red: #f12a23;--tertiary-purple: #b67cff;--tertiary-green: #8ad56c;--surface-strong: #080808;--surface-soft: rgba(255, 255, 255, .06);--surface-muted: rgba(255, 255, 255, .08);--surface-overlay: rgba(5, 5, 5, .92);--surface-overlay-start: rgba(10, 10, 10, .58);--surface-overlay-end: rgba(5, 5, 5, .94);--border-color: rgba(255, 255, 255, .08);--input-background: #090909;--notification-foreground: #efefec;--shadow-soft: none;--panel-border: rgba(255, 255, 255, .06)}html{box-sizing:border-box;font-size:16px;background-color:var(--primary-grey)}*,*: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%;transition:background-color .35s ease,color .35s ease}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,.theme-toggle,.contact-form input,.contact-form textarea{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),.theme-toggle:not(.animating),.contact-form input:not(.animating),.contact-form textarea: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%}.app-shell{position:relative;min-height:100vh}.app-background{position:fixed;inset:0;z-index:0;pointer-events:none}.app-background canvas{width:100%!important;height:100%!important;pointer-events:none}.app-content{position:relative;z-index:1}@media screen and (max-width: 768px){.app-background,#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}
