.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none;opacity:0;animation:fadeUp .6s ease .36s forwards}.hamburger span{display:block;width:22px;height:1.5px;background:var(--ink);transition:.3s}.mobile-drawer{display:none;position:fixed;top:0;right:0;width:70vw;max-width:280px;height:100vh;background:var(--white);border-left:1px solid var(--border);padding:5rem 2rem 2rem;flex-direction:column;gap:1.5rem;z-index:1000;transform:translate(100%);transition:transform .3s ease}.mobile-drawer.open{transform:translate(0)}.mobile-drawer a{font-family:Figtree,sans-serif;font-size:1.2rem;color:var(--muted);text-decoration:none}.mobile-drawer a:hover{color:var(--ink)}.drawer-scrim{display:none;position:fixed;inset:0;background:#0003;z-index:900}@media(max-width:1024px){.hamburger,.mobile-drawer{display:flex}.drawer-scrim{display:block;visibility:hidden}.drawer-scrim.active{visibility:visible}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--white: #ffffff;--off-white: #f3f1ee;--off-off-white: #c4c2c0;--grey: #9b9a9a;--dark-grey: #434343;--dark-background: #242526;--ink: #1a1a1a;--muted: #888;--border: rgba(0,0,0,.08);--light-border: rgba(255, 255, 255, .08);--header-h: 52px}html,body{min-height:100%;overflow-x:hidden;overflow-y:auto;scroll-behavior:smooth;background:var(--off-white);color:var(--ink);font-family:Figtree,sans-serif;font-weight:300}header{position:fixed;top:0;left:0;right:0;height:var(--header-h);background:#f7f5f2d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 2rem;z-index:100}.header-logo{font-size:1rem;text-decoration:none;color:var(--muted);letter-spacing:.01em;opacity:0;animation:fadeUp .6s ease .1s forwards}.header-logo:hover{color:var(--ink)}.header-title{text-align:center;font-size:.9rem;text-decoration:none;color:var(--muted);letter-spacing:.1em;opacity:0;animation:fadeUp .6s ease .2s forwards}nav{display:flex;align-items:center;gap:2rem}nav a{font-family:Figtree,sans-serif;font-size:.8rem;font-weight:300;letter-spacing:.08em;text-transform:lowercase;color:var(--muted);text-decoration:none;transition:color .2s;opacity:0;animation:fadeUp .6s ease forwards}nav a:nth-child(1){animation-delay:.15s}nav a:nth-child(2){animation-delay:.22s}nav a:nth-child(3){animation-delay:.29s}nav a:nth-child(4){animation-delay:.36s}nav a:hover{color:var(--ink)}main{min-height:100vh;padding-top:var(--header-h);display:grid;grid-template-columns:1fr 1fr;gap:0}.left{display:flex;flex-direction:column;justify-content:center;padding:3rem 3rem 3rem 4rem;opacity:0;animation:fadeUp .7s ease .3s forwards}.eyebrow{font-family:retro,sans-serif;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem}h1{font-family:gloudy;font-size:clamp(3rem,4vw,5rem);font-weight:300;line-height:1.1;color:var(--ink);margin-bottom:.5rem}.subtitle{font-family:Figtree,serif;font-size:clamp(1rem,1.1vw,1.25rem);font-weight:300;color:var(--muted);margin-bottom:2.5rem;letter-spacing:.02em}.links-list{list-style:none;display:flex;flex-direction:column;gap:0}.links-list li{border-top:1px solid var(--border)}.links-list li:last-child{border-bottom:1px solid var(--border)}.links-list a{display:flex;align-items:center;justify-content:space-between;padding:.85rem 0;font-family:Figtree,serif;font-size:clamp(.85rem,.85vw,.85rem);font-weight:100;color:var(--ink);text-decoration:none;transition:color .2s,padding-left .2s}.links-list a:hover{color:var(--muted);padding-left:.5rem}.links-list a .arrow{font-size:.75rem;opacity:0;transition:opacity .2s}.links-list a:hover .arrow{opacity:1}.tag{font-family:retro;font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);background:var(--border);padding:2px 6px;border-radius:2px}.right{position:relative;overflow:hidden;opacity:0;animation:fadeIn .9s ease .5s forwards}.gradient-blob{position:absolute;inset:1.5rem;border-radius:4px;background:conic-gradient(from 200deg at 40% 60%,#a8edcc,#f9e070,#f7a541,#f06b8a,#c96ddb,#7b9ef7,#a8edcc 360deg);filter:blur(0px);animation:hueShift 12s linear infinite}@keyframes hueShift{0%{filter:hue-rotate(0deg)}to{filter:hue-rotate(360deg)}}.gradient-blob:after{content:"";position:absolute;inset:0;border-radius:4px;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 150 150' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.08'/%3E%3C/svg%3E");background-size:150px 150px;opacity:.4;mix-blend-mode:overlay;pointer-events:none}.footer-strip{font-family:Figtree,sans-serif;position:fixed;bottom:0;left:0;right:0;height:32px;display:flex;align-items:center;justify-content:center;text-align:center;font-size:.65rem;letter-spacing:.12em;color:var(--muted);background:#f7f5f2b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid var(--border);z-index:100}.mobile-popup{display:none;position:fixed;bottom:40px;left:50%;transform:translate(-50%);width:min(90vw,380px);background:#ffffffd9;backdrop-filter:blur(1px);-webkit-backdrop-filter:blur(1px);border:1px solid var(--border);border-radius:8px;padding:1.1rem 1.25rem;z-index:200;box-shadow:0 8px 32px #0000001a;animation:slideUp .4s ease forwards}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes fadeOut{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(12px)}}.mobile-popup.hiding{animation:fadeOut .4s ease forwards}.popup-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.popup-title{font-family:retro;font-size:1rem;font-weight:400}.popup-close{background:none;border:1px solid var(--border);border-radius:4px;font-family:retro;font-size:.7rem;letter-spacing:.08em;color:var(--muted);cursor:pointer;padding:3px 10px;transition:color .2s,border-color .2s}.popup-close:hover{color:var(--ink);border-color:var(--ink)}.popup-body p{font-family:retro;font-size:.78rem;font-weight:300;color:var(--muted);line-height:1.6}.end-of-page{text-align:center;margin-top:0;margin-bottom:10px;opacity:0;animation:fadeUp .6s ease .45s forwards}.end-of-page a{display:flex;align-items:center;justify-content:center;gap:8px;color:var(--muted)}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:1024px){nav{display:none}.hamburger{display:flex}}@media(max-width:768px){html,body{overflow:auto;height:auto}main{grid-template-columns:1fr;grid-template-rows:auto auto;height:auto;min-height:unset;padding-top:var(--header-h);padding-bottom:40px}.left{padding:2rem 1.5rem 3rem;order:1}.header-title{font-size:.75rem}.right{order:0;height:55vw;min-height:200px;max-height:340px}.gradient-blob{inset:0;border-radius:0}nav{display:none}}@media(max-width:480px){.header-title{font-size:.6rem}}@font-face{font-family:retro;src:url(/audio-visualizer/assets/Retro-Gaming-B_OnpYhl.ttf) format("truetype")}.retro-text{font-family:retro}@font-face{font-family:bmspa;src:url(/audio-visualizer/assets/BMSPA___-8j0MoF3V.TTF) format("truetype")}.bmspa-text{font-family:bmspa}@font-face{font-family:"04b03";src:url(/audio-visualizer/assets/04B_03__-BotmnRBD.TTF) format("truetype")}.b03-text{font-family:"04b03"}@font-face{font-family:blacksignature;src:url(/audio-visualizer/assets/BlackSignature-jknKQGo_.otf) format("opentype")}.blacksignature-text{font-family:blacksignature}@font-face{font-family:mondwest;src:url(/audio-visualizer/assets/ppmondwest-regular-DbXiRSX3.otf) format("opentype")}.mondwest-text{font-family:mondwest}@font-face{font-family:gloudy;src:url(/audio-visualizer/assets/GloudyPixel-Regular-Dqn9lpim.otf) format("opentype")}.gloudy-text{font-family:gloudy}html.dark,body.dark{background-color:var(--dark-background)}body.dark main,body.dark #main{background-color:var(--dark-background)}body.dark main a{color:var(--off-white)}body.dark h1,body.dark h3{color:var(--white)}body.dark .subtitle,body.dark .eyebrow,body.dark .links-list a{color:var(--off-off-white)}body.dark .links-list a:hover{color:var(--white)}body.dark .links-list li{border-top:1px solid var(--light-border)}body.dark .links-list li:last-child{border-bottom:1px solid var(--light-border)}body.dark .filter-btn{color:var(--off-white);border:1px solid var(--light-border)}body.dark .filter-btn:hover,body.dark .filter-btn.active{color:var(--white);border-color:var(--off-off-white);background:var(--dark-grey)}body.dark .project-card{background:var(--dark-background);border:1px solid var(--light-border)}body.dark .project-card:after{color:var(--off-off-white)}body.dark .project-card:hover{background:var(--ink)}body.dark .card-name{color:var(--off-white)}body.dark .card-tag{color:var(--off-off-white);background:var(--light-border)}body.dark header{z-index:200;background:#1212148c!important;border-bottom-color:#ffffff14!important}body.dark header .header-logo,body.dark header nav a{color:var(--muted)}body.dark header .header-logo:hover,body.dark header nav a:hover{color:var(--white)}body.dark .hamburger span{background:#c8c8cdbf}body.dark .mobile-drawer{background:#121214!important;border-left-color:#ffffff14!important;z-index:300!important}body.dark .mobile-drawer a{color:#c8c8cd!important}body.dark .mobile-drawer a:hover{color:var(--white)!important}body.dark .drawer-scrim{z-index:250!important}body.dark .footer-strip{background:#1212148c!important;border-top-color:#ffffff14!important;color:#c8c8cd80}body.dark .mobile-popup{background:#121214d9;border-color:#ffffff14;box-shadow:0 8px 32px #0006;backdrop-filter:blur(1px);-webkit-backdrop-filter:blur(1px)}body.dark .popup-title{color:var(--off-white)}body.dark .popup-close{border-color:#ffffff14;color:var(--muted)}body.dark .popup-close:hover{color:var(--white);border-color:#ffffff4d}body.dark .popup-body p{color:var(--muted)}
