@import"https://fonts.googleapis.com/css2?family=Matangi:wght@300..900&family=Rubik+80s+Fade&display=swap";@import"https://fonts.googleapis.com/css2?family=Edu+AU+VIC+WA+NT+Arrows:wght@400..700&display=swap";@import"https://fonts.googleapis.com/css2?family=Reenie+Beanie&display=swap";@import"https://fonts.googleapis.com/css2?family=Lexend:wght@100..900&display=swap";*,*:before,*:after{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:#090910;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-shell{min-height:100vh;@keyframes iconPulseA{0%{transform:scale(.93)}22%{transform:scale(1.09)}49%{transform:scale(.96)}74%{transform:scale(1.12)}to{transform:scale(.93)}}@keyframes iconPulseB{0%{transform:scale(1.07)}18%{transform:scale(.915)}44%{transform:scale(1.11)}71%{transform:scale(.95)}to{transform:scale(1.07)}}@keyframes iconPulseC{0%{transform:scale(.95)}26%{transform:scale(1.125)}52%{transform:scale(.92)}79%{transform:scale(1.085)}to{transform:scale(.95)}}}.app-shell .app-shell.home-route{background:#d7d7df;font-family:Matangi,sans-serif}.app-shell .top-nav{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.18);background:#2f2f33bf;position:sticky;top:0;z-index:10}.app-shell .top-nav-left,.app-shell .top-nav-right{display:flex;align-items:center;gap:1rem}.app-shell .hamburger-btn{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:4px}.app-shell .hamburger-bar{display:block;width:24px;height:2px;background:#fff;border-radius:2px}.app-shell .nav-menu{display:flex;justify-content:space-between;align-items:center;flex:1}.app-shell .nav-link{font-family:Lexend,sans-serif;color:#fff;text-decoration:none;font-weight:300;font-size:1rem;line-height:1.2;letter-spacing:.03em}.app-shell .top-nav-left .nav-link{font-size:1.25rem}.app-shell .nav-link-button{border:0;background:transparent;padding:0;cursor:pointer;font:inherit;line-height:inherit}.app-shell .auth-action{border:1px solid rgba(255,255,255,.5);border-radius:999px;padding:.45rem 1rem;font-family:Lexend,sans-serif;font-size:1.06rem}.app-shell .auth-user{max-width:min(260px,30vw);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#ffffffd9;font-family:Lexend,sans-serif;font-size:.88rem}.app-shell .nav-link.active{color:#f6f8ff}.app-shell .synth-link-locked{color:#ff5e5e;font-family:Lexend,sans-serif}.app-shell .synth-link-unlocked,.app-shell .synth-link-unlocked.active{color:#6dff8b;font-family:Lexend,sans-serif}.app-shell .app-shell.home-route .top-nav{border-bottom:1px solid rgba(255,255,255,.18);background:#2f2f33bf;position:fixed;top:0;left:0;right:0}.app-shell .app-shell.home-route .nav-link{color:#fff}.app-shell .app-shell.home-route .nav-link.synth-link-locked{color:#ff5e5e}.app-shell .app-shell.home-route .nav-link.synth-link-unlocked,.app-shell .app-shell.home-route .nav-link.synth-link-unlocked.active{color:#6dff8b}.app-shell .app-shell.home-route .nav-link.active{color:#f6f8ff}.app-shell .auth-modal-overlay{position:fixed;inset:0;background:#0000009e;display:grid;place-items:center;z-index:30;padding:1rem}.app-shell .auth-modal{width:min(440px,100%);border-radius:16px;border:1px solid rgba(255,255,255,.16);background:#18181ef5;color:#fff;padding:1.25rem;position:relative;box-shadow:0 24px 64px #00000073}.app-shell .auth-modal h2{margin:0 0 .9rem;font-family:Lexend,sans-serif;font-weight:500}.app-shell .synth-gate-modal{text-align:center}.app-shell .synth-gate-message{margin:0 0 1rem;font-family:Lexend,sans-serif;color:#ff5e5e}.app-shell .auth-close{position:absolute;top:.55rem;right:.7rem;border:0;background:transparent;color:#fffc;font-size:1.2rem;cursor:pointer}.app-shell .auth-form{display:grid;gap:.8rem}.app-shell .auth-form label{display:grid;gap:.35rem;font-family:Lexend,sans-serif;font-size:.9rem}.app-shell .auth-form input{border-radius:8px;border:1px solid rgba(255,255,255,.2);background:#ffffff0f;color:#fff;padding:.6rem .7rem;font-family:Lexend,sans-serif;font-size:16px}.app-shell .auth-submit,.app-shell .auth-switch{border-radius:8px;padding:.6rem .8rem;border:1px solid rgba(255,255,255,.22);font-family:Lexend,sans-serif;cursor:pointer}.app-shell .auth-submit{background:#ffffff24;color:#fff}.app-shell .auth-submit:disabled{opacity:.65;cursor:not-allowed}.app-shell .auth-switch{margin-top:.8rem;width:100%;background:transparent;color:#ffffffd6}.app-shell .auth-error,.app-shell .auth-notice{margin:0;font-family:Lexend,sans-serif;font-size:.86rem}.app-shell .auth-error{color:#ff8e8e}.app-shell .auth-notice{color:#93f7b1}.app-shell .page-shell{width:min(1100px,100%);margin:0 auto}.app-shell .home-page{width:100%;max-width:none}.app-shell .hero-3d{position:relative;width:100%;min-height:calc(100vh - 66px);overflow:hidden;--hero-up-shift: 15%;--hero-side-inset: 20%;--hero-overlay-drop: 44px}.app-shell .hero-3d:after{content:"";position:absolute;inset:0;background:#0000004d;pointer-events:none;z-index:1}.app-shell .hero-3d canvas{display:block;width:100%!important;height:min(760px,calc(100vh - 66px))!important}.app-shell .hero-overlay-content{display:contents}.app-shell .hero-portrait-wrap{position:absolute;top:calc(50% - var(--hero-up-shift) + var(--hero-overlay-drop));right:var(--hero-side-inset);width:clamp(180px,26vw,360px);aspect-ratio:1 / 1;transform:translateY(-50%);border-radius:50%;overflow:hidden;pointer-events:none;box-shadow:0 18px 42px #00000047,0 0 0 5px #ffffffc7;z-index:2}.app-shell .hero-text-block{position:absolute;top:calc(50% - var(--hero-up-shift) + var(--hero-overlay-drop));left:var(--hero-side-inset);transform:translateY(-50%);pointer-events:none;z-index:3;filter:drop-shadow(34px 26px 34px rgba(0,0,0,.9)) drop-shadow(16px 12px 18px rgba(0,0,0,.75))}.app-shell .hero-name-label{margin:0 0 .35em;font-family:Reenie Beanie,sans-serif;font-weight:400;font-size:clamp(2.8rem,6.2vw,6.4rem);letter-spacing:.08em;line-height:1.1;color:#fff;text-align:center;white-space:nowrap;text-shadow:0 3px 14px rgba(0,0,0,.55)}.app-shell .hero-left-label{margin:0;font-family:Edu AU VIC WA NT Arrows,sans-serif;font-weight:700;font-style:italic;font-size:clamp(1.2rem,2.7vw,2.6rem);letter-spacing:.08em;line-height:1.1;color:#fff;text-transform:lowercase;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.1em;text-shadow:0 0 12px rgba(255,255,255,.85),0 3px 14px rgba(0,0,0,.55);background:#00000080;padding:.2em .7em .45em;border-radius:.5em}.app-shell .hero-portrait-image{width:100%;height:100%;display:block;object-fit:cover}.app-shell .hero-social-icons{position:absolute;left:var(--hero-side-inset);right:var(--hero-side-inset);bottom:calc(clamp(.9rem,2.5vh,1.6rem) + var(--hero-up-shift) - var(--hero-overlay-drop));display:flex;align-items:center;justify-content:space-between;gap:0;z-index:2}.app-shell .hero-social-icon{width:clamp(4rem,5.8vw,4.9rem);height:clamp(4rem,5.8vw,4.9rem);border-radius:999px;border:1px solid rgba(255,255,255,.5);background:#0f101573;color:#7f8694;display:inline-flex;align-items:center;justify-content:center;font-size:clamp(1.8rem,2.5vw,2.1rem);cursor:pointer;transition:background .2s ease;animation-duration:10.8s;animation-iteration-count:infinite;animation-timing-function:ease-in-out;animation-fill-mode:both;transform-origin:center}.app-shell .hero-social-icon:hover{background:#0f1015b3}.app-shell .hero-social-icon:nth-child(1){animation-name:iconPulseA;animation-duration:9.9s;animation-delay:-.7s}.app-shell .hero-social-icon:nth-child(2){animation-name:iconPulseB;animation-duration:11.85s;animation-delay:-2.1s}.app-shell .hero-social-icon:nth-child(3){animation-name:iconPulseC;animation-duration:9.3s;animation-delay:-1.4s}.app-shell .hero-social-icon:nth-child(4){animation-name:iconPulseB;animation-duration:10.95s;animation-delay:-.9s}.app-shell .hero-social-icon:nth-child(5){animation-name:iconPulseA;animation-duration:10.2s;animation-delay:-1.7s}.app-shell .home-next-section{min-height:calc(100vh - 66px);position:relative;overflow:hidden}.app-shell .section-bg-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}.app-shell .site-footer{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:1rem 1.25rem;border-top:1px solid rgba(255,255,255,.18);background:#2f2f33bf;width:100%}.app-shell .footer-links{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;justify-content:center}.app-shell .footer-copyright{margin:0;font-family:Lexend,sans-serif;font-size:.82rem;font-weight:300;color:#ffffff8c;text-align:center}.app-shell .section-bg-overlay{position:absolute;inset:0;background:#000;z-index:1;opacity:1;transition:opacity 10s ease}.app-shell .home-next-section.in-view .section-bg-overlay{opacity:.3;transition:opacity 25s ease}.app-shell .section-content{position:relative;z-index:2;padding:2.5rem 1.5rem;max-width:700px;margin:0 auto}.app-shell .about-page{padding:3rem 1.25rem;color:#f0f4ff;display:flex;flex-direction:column;align-items:center}.app-shell .about-page-title{font-family:Lexend,sans-serif;font-weight:600;font-size:2rem;color:#f6f8ff;margin:0 0 1.5rem;text-align:center}.app-shell .about-me-text{max-width:700px;margin:0 auto}.app-shell .about-me-text p{font-family:Lexend,sans-serif;font-size:1.05rem;font-weight:300;line-height:1.75;color:#e0e4f0;margin:0 0 1.25rem}.app-shell .about-social-icons{display:flex;justify-content:center;gap:1.5rem;margin-top:3.5rem;margin-bottom:3.5rem}.app-shell .contact-page{padding:3rem 1.25rem 4rem;display:flex;justify-content:center;color:#f0f4ff}.app-shell .contact-panel{width:min(720px,100%);margin:0 auto}.app-shell .contact-page-title{margin:0 0 1rem;text-align:center;font-family:Lexend,sans-serif;font-size:2rem;font-weight:600;color:#f6f8ff}.app-shell .contact-page-intro{margin:0 auto 2rem;max-width:640px;text-align:center;font-family:Lexend,sans-serif;font-size:1rem;font-weight:300;line-height:1.75;color:#e0e4f0}.app-shell .contact-form{display:grid;gap:1rem;padding:1.5rem;border-radius:18px;border:1px solid rgba(255,255,255,.16);background:#18181eb8;box-shadow:0 24px 64px #0003}.app-shell .contact-form label{display:grid;gap:.45rem;font-family:Lexend,sans-serif;font-size:.95rem;color:#f0f4ff}.app-shell .contact-form input,.app-shell .contact-form textarea{border-radius:10px;border:1px solid rgba(255,255,255,.18);background:#ffffff0f;color:#fff;padding:.75rem .85rem;font-family:Lexend,sans-serif;font-size:.98rem;resize:vertical}.app-shell .contact-form input:focus,.app-shell .contact-form textarea:focus{outline:1px solid rgba(255,255,255,.34);outline-offset:0}.app-shell .contact-honeypot{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}.app-shell .contact-error,.app-shell .contact-notice{margin:0;font-family:Lexend,sans-serif;font-size:.92rem}.app-shell .contact-error{color:#ff9d9d}.app-shell .contact-notice{color:#a7f4ba}.app-shell .contact-submit{justify-self:center;min-width:180px;border:1px solid rgba(255,255,255,.24);border-radius:999px;background:#ffffff1f;color:#fff;padding:.8rem 1.4rem;font-family:Lexend,sans-serif;font-size:1rem;cursor:pointer}.app-shell .contact-submit:disabled{opacity:.65;cursor:not-allowed}@media(max-width:670px){.app-shell .hamburger-btn{display:flex}.app-shell .nav-menu{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;padding:1.2rem 1rem;gap:1rem;background:#2f2f33f7;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.18);max-height:calc(100vh - 64px);overflow-y:auto}.app-shell .nav-menu-open{display:flex}.app-shell .top-nav-left,.app-shell .top-nav-right{width:100%;flex-direction:column;align-items:center;gap:.85rem}.app-shell .top-nav-left .nav-link{font-size:1.15rem}.app-shell .auth-user{max-width:80vw}.app-shell .hero-3d{--hero-side-inset: .75rem;touch-action:pan-y;display:flex;flex-direction:column;align-items:center;min-height:0;height:calc(100vh - 66px);height:calc(100dvh - 66px);overflow:hidden}.app-shell .hero-3d>div{touch-action:pan-y!important}.app-shell .hero-3d>div:first-child{position:absolute!important;inset:0;width:100%!important;height:100%!important}.app-shell .hero-3d canvas{width:100%!important;height:100%!important}.app-shell .hero-overlay-content{display:flex;flex-direction:column;align-items:center;position:relative;top:auto;left:auto;transform:none;z-index:3;gap:1rem;pointer-events:none;flex:1;justify-content:center}.app-shell .hero-portrait-wrap{position:relative;inset:auto;transform:none;width:clamp(187px,52vw,244px)}.app-shell .hero-text-block{position:relative;top:auto;left:auto;bottom:auto;transform:none;filter:drop-shadow(12px 10px 14px rgba(0,0,0,.9))}.app-shell .hero-name-label{font-size:clamp(2.6rem,13vw,3.6rem);white-space:nowrap}.app-shell .hero-left-label{font-size:clamp(1.38rem,6.8vw,1.8rem)}.app-shell .hero-social-icons{position:relative;left:auto;right:auto;bottom:auto;width:100%;padding:0 .75rem;margin-top:auto;margin-bottom:2vh;justify-content:center;gap:.75rem}.app-shell .hero-social-icon{width:3.4rem;height:3.4rem;font-size:1.5rem}.app-shell .section-content{padding:2rem 1rem}.app-shell .footer-links{flex-direction:column;gap:.9rem}.app-shell .about-page{padding:2.25rem 1rem 3rem}.app-shell .about-page-title{font-size:1.75rem}.app-shell .about-me-text p{font-size:.98rem;line-height:1.65}.app-shell .about-social-icons{flex-wrap:wrap;gap:1rem;margin-top:2.5rem;margin-bottom:2.5rem}.app-shell .contact-page{padding:2.25rem 1rem 3rem}.app-shell .contact-page-title{font-size:1.75rem}.app-shell .contact-page-intro{font-size:.98rem;line-height:1.65}.app-shell .contact-form{padding:1.2rem}.app-shell .contact-form input,.app-shell .contact-form textarea{font-size:16px}.app-shell .contact-submit{width:100%}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.gf-synth{--gf-bg: #090910;--gf-surface: #10101c;--gf-surface2: #16162a;--gf-border: #2a2a4a;--gf-accent: #7c3aed;--gf-accent2: #06b6d4;--gf-text: #e2e2f0;--gf-text-dim: #6b6b8a;--gf-glow: 0 0 18px #7c3aed88;--gf-glow2: 0 0 18px #06b6d488;--gf-radius: 10px;--gf-font: "Courier New", Courier, monospace;background:var(--gf-bg);color:var(--gf-text);font-family:var(--gf-font);display:flex;flex-direction:column;gap:1.4rem;padding:1.5rem 1rem;border-radius:var(--gf-radius);box-sizing:border-box}.gf-synth *,.gf-synth *:before,.gf-synth *:after{box-sizing:border-box;margin:0;padding:0}.gf-header{text-align:center}.gf-title{font-size:clamp(2rem,6vw,3rem);font-weight:900;letter-spacing:.12em;line-height:1;font-family:var(--gf-font)}.gf-grain{color:var(--gf-accent);text-shadow:0 0 28px var(--gf-accent)}.gf-forge{color:var(--gf-accent2);text-shadow:0 0 28px var(--gf-accent2);margin-left:.25em}.gf-subtitle{font-size:.68rem;letter-spacing:.28em;color:var(--gf-text-dim);margin-top:.4rem;font-family:var(--gf-font);text-transform:uppercase}.gf-scope-container{position:relative;border:1px solid var(--gf-border);border-radius:var(--gf-radius);overflow:hidden;background:#0d0d14;box-shadow:var(--gf-glow2)}.gf-scope-canvas{display:block;width:100%;height:auto}.gf-scope-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#090910d1;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.gf-start-btn{background:transparent;border:2px solid var(--gf-accent);color:var(--gf-accent);font-family:var(--gf-font);font-size:1rem;letter-spacing:.25em;padding:.75em 2.2em;border-radius:6px;cursor:pointer;text-shadow:var(--gf-glow);box-shadow:var(--gf-glow);transition:background .18s,color .18s}.gf-start-btn:hover{background:var(--gf-accent);color:#fff;border-color:var(--gf-accent)}.gf-mobile-modal-backdrop{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.gf-mobile-modal{display:flex;flex-direction:column;align-items:center;gap:1.2rem;background:var(--gf-surface);border:1px solid var(--gf-border);border-radius:14px;padding:2.4rem 2rem;margin:0 1.2rem;box-shadow:0 0 40px #7c3aed40;text-align:center}.gf-mobile-modal-title{font-size:1.8rem;font-weight:900;letter-spacing:.12em;line-height:1;font-family:var(--gf-font)}.gf-mobile-modal-text{color:var(--gf-text-dim);font-size:.85rem;font-family:var(--gf-font)}.gf-controls-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.gf-section{background:var(--gf-surface);border:1px solid var(--gf-border);border-radius:var(--gf-radius);padding:1.2rem 1.1rem;display:flex;flex-direction:column;gap:1.1rem}.gf-section-title{font-size:.7rem;letter-spacing:.3em;color:var(--gf-accent2);text-shadow:var(--gf-glow2);border-bottom:1px solid var(--gf-border);padding-bottom:.55rem;font-weight:700;font-family:var(--gf-font)}.gf-knob-wrapper{display:flex;flex-direction:column;gap:.4rem}.gf-knob-top{display:flex;justify-content:space-between;align-items:baseline}.gf-knob-label{font-size:.65rem;letter-spacing:.18em;color:var(--gf-text-dim);text-transform:uppercase;font-family:var(--gf-font)}.gf-knob-value{font-size:.75rem;color:var(--gf-accent2);letter-spacing:.1em;font-family:var(--gf-font)}.gf-knob-slider{-webkit-appearance:none;appearance:none;width:100%;height:4px;background:var(--gf-surface2);border-radius:2px;outline:none;border:1px solid var(--gf-border);cursor:pointer}.gf-knob-slider:hover{background:var(--gf-border)}.gf-knob-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--gf-accent);border:2px solid var(--gf-accent2);box-shadow:var(--gf-glow);cursor:pointer;transition:box-shadow .15s}.gf-knob-slider::-webkit-slider-thumb:hover{box-shadow:0 0 26px var(--gf-accent)}.gf-knob-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--gf-accent);border:2px solid var(--gf-accent2);box-shadow:var(--gf-glow);cursor:pointer}.gf-wave-select{background:var(--gf-surface2);border:1px solid var(--gf-border);color:var(--gf-text);font-family:var(--gf-font);font-size:.85rem;padding:.45em .7em;border-radius:5px;cursor:pointer;outline:none;width:100%}.gf-wave-select:focus{border-color:var(--gf-accent)}.gf-keyboard-section{background:var(--gf-surface);border:1px solid var(--gf-border);border-radius:var(--gf-radius);padding:1.4rem 1.2rem}.gf-kb-title{text-align:center;margin-bottom:1.2rem;display:flex;align-items:center;justify-content:center;gap:1.2rem;border-bottom:none!important;padding-bottom:0!important}.gf-key-hint{font-size:.62rem;color:var(--gf-text-dim);letter-spacing:.18em;font-weight:400}.gf-keyboard{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}.gf-key{width:80px;height:120px;background:linear-gradient(180deg,var(--gf-surface2) 0%,#0b0b1f 100%);border:1px solid var(--gf-border);border-radius:7px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding-bottom:.9rem;gap:.3rem;cursor:pointer;font-family:var(--gf-font);transition:all .08s ease;color:var(--gf-text-dim);-webkit-user-select:none;user-select:none;touch-action:none}.gf-key:hover{border-color:var(--gf-accent);box-shadow:var(--gf-glow);color:var(--gf-text)}.gf-key-active{background:linear-gradient(180deg,var(--gf-accent) 0%,#3b1a7a 100%)!important;border-color:var(--gf-accent2)!important;box-shadow:var(--gf-glow),var(--gf-glow2)!important;color:#fff!important;transform:translateY(2px)}.gf-key-note{font-size:.82rem;font-weight:700;letter-spacing:.05em}.gf-key-shortcut{font-size:.62rem;letter-spacing:.18em;opacity:.55}.gf-footer{text-align:center;font-size:.62rem;color:var(--gf-text-dim);letter-spacing:.22em;padding-top:.5rem;border-top:1px solid var(--gf-border);font-family:var(--gf-font);text-transform:uppercase}@media(max-width:1024px){.gf-controls-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:670px){.gf-start-btn{white-space:nowrap;font-size:clamp(.62rem,3.2vw,1rem);letter-spacing:.12em;padding:.65em 1.2em}.gf-keyboard{flex-wrap:nowrap;gap:.25rem}.gf-key{width:0;flex:1 1 0;min-width:0;height:72px;padding-bottom:.5rem;border-radius:5px;gap:.15rem}.gf-key-note{font-size:.6rem}.gf-key-shortcut{font-size:.48rem}.gf-keyboard-section{padding:1rem .6rem}}
