@font-face{font-family:Satoshi;src:url(https://api.fontshare.com/v2/fonts/satoshi/woff2) format("woff2"),url(https://api.fontshare.com/v2/fonts/satoshi/woff) format("woff");font-weight:400;font-display:swap;font-style:normal}@font-face{font-family:Satoshi;src:url(https://api.fontshare.com/v2/fonts/satoshi/woff2) format("woff2"),url(https://api.fontshare.com/v2/fonts/satoshi/woff) format("woff");font-weight:700;font-display:swap;font-style:normal}*{scroll-behavior:smooth}:root{font-family:Satoshi,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#000000de;background-color:#fff;min-height:100vh;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{scroll-behavior:smooth}a{font-weight:500;color:#000;text-decoration:inherit}a:hover{color:#333}body{margin:0;min-width:320px;min-height:100vh;background-color:#fff;background-attachment:fixed}h1{font-size:3.2em;line-height:1.1;color:#000}button{border-radius:8px;border:1px solid #000000;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#fff;color:#000;cursor:pointer;transition:all .25s}button:hover{background-color:#000;color:#fff}button:focus,button:focus-visible{outline:2px solid #000000;outline-offset:2px}#root{width:100%;margin:0;padding:0;position:relative}.app{width:100%}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:clamp(1.5rem,3vw,2rem);text-align:center;position:relative;overflow:hidden}.contact{padding:6rem 2rem;max-width:1400px;width:100%;margin:0 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;background:transparent;color:#000;text-align:center;position:relative}.contact>*{position:relative;z-index:2}.contact h2,.contact .contact-info{position:relative;z-index:2}.contact h2{margin-bottom:3rem;font-size:clamp(2.5rem,5vw,4rem);color:#000;font-weight:700;letter-spacing:-.02em}.contact-info{display:flex;flex-direction:column;align-items:center;gap:1rem}.contact-info p{font-size:clamp(1rem,2vw,1.2rem);color:#000;margin:0;opacity:.8}.social-links{display:flex;gap:clamp(1rem,3vw,2rem);margin-top:clamp(.75rem,2vw,1rem);flex-wrap:wrap;justify-content:center}.social-links a{padding:.75rem 1.5rem;background-color:#000;color:#fff;text-decoration:none;border-radius:8px;font-weight:600;border:2px solid #000000}.social-links a:hover{background-color:#fff;color:#000}footer{padding:2rem;margin-top:2rem;text-align:center;color:#000;font-size:.9rem;background-color:transparent;opacity:.6}@media (max-width: 768px){.contact{padding:3rem 2rem}.social-links{flex-direction:column;gap:1rem}.social-links a{padding:1rem 2rem}}.about{padding:6rem 2rem;max-width:1400px;width:100%;margin:0 auto;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:4rem;background:transparent;color:#000}.about-content{flex:1;text-align:left;max-width:600px}.about-github{flex:0 0 auto;display:flex;align-items:center;justify-content:center}.about-github a{display:block;transition:opacity .2s ease}.about-github a:hover{opacity:.7}.about-github img{width:200px;height:auto;display:block}.headshot{width:250px;height:250px;object-fit:cover;border-radius:15px}.about h2{margin-bottom:1.5rem;font-size:clamp(2rem,4vw,3rem);color:#000;font-weight:700}.about p{font-size:clamp(1rem,2vw,1.2rem);line-height:1.8;color:#000;margin-bottom:0}@media (max-width: 768px){.about{flex-direction:column;text-align:center;padding:4rem 2rem;gap:3rem}.about-content{text-align:center;max-width:100%}.about-github img{width:150px}}.skills{padding:6rem 2rem;max-width:1400px;margin:0 auto;background:transparent;color:#000}.skills h2{margin-bottom:4rem;text-align:center;font-size:clamp(2.5rem,5vw,4rem);color:#000;font-weight:700;letter-spacing:-.02em}.skills-grid{display:flex;flex-direction:column;gap:4rem;align-items:center}.skill-category{width:100%;max-width:900px;text-align:center}.skill-category h3{margin-bottom:1.5rem;color:#000;font-size:clamp(1.2rem,2.5vw,1.8rem);font-weight:600;letter-spacing:-.01em;text-transform:uppercase;opacity:.6}.skill-list{display:flex;flex-wrap:wrap;gap:.8rem 1.2rem;margin:0;padding:0;list-style:none;justify-content:center;line-height:1.8}.skill-item{background:transparent;padding:0 1rem;border:none;font-size:clamp(1rem,2vw,1.3rem);color:#000;font-weight:400;cursor:default}@media (max-width: 768px){.skills{padding:4rem 1.5rem}.skills h2{margin-bottom:3rem}.skills-grid{gap:3rem}.skill-item{font-size:clamp(.9rem,2.5vw,1.1rem)}}@media (max-width: 480px){.skills{padding:3rem 1rem}.skill-list{gap:.6rem .8rem}}.projects{padding:6rem 2rem;max-width:1400px;margin:0 auto;background:transparent;color:#000}.projects h2{margin-bottom:4rem;text-align:center;font-size:clamp(2.5rem,5vw,4rem);color:#000;font-weight:700;letter-spacing:-.02em}.project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:2rem;position:relative;z-index:1}.project-card{background:transparent;padding:1.5rem;display:flex;flex-direction:column;min-height:450px}.project-card h3{margin-bottom:1rem;color:#000;font-size:clamp(1.3rem,2.5vw,1.8rem);font-weight:600}.project-card p{color:#000;margin-bottom:1rem;line-height:1.6;opacity:.8}.project-card a{color:#000;text-decoration:none;font-weight:600;margin-bottom:2rem;display:inline-block;border-bottom:1px solid #000000;padding-bottom:2px}.project-card a:hover{opacity:.6}.project-content{flex:1;display:flex;flex-direction:column}.project-media{margin-top:auto}.ios-apps{display:flex;gap:2rem;justify-content:center;margin-top:2rem}.app-card{text-align:center;padding:1rem;min-width:140px;display:flex;flex-direction:column;align-items:center}.app-card:hover{opacity:.8}.app-logo{width:120px;height:120px;object-fit:cover;object-position:center;border-radius:22px;margin-bottom:1rem}.app-name{font-size:1.1rem;color:#000;margin-top:.5rem;font-weight:600}.project-logo{margin-top:auto;display:flex;justify-content:center;align-items:center;height:220px;padding-bottom:80px}.company-logo{width:180px;height:180px;object-fit:cover;border-radius:35px;padding:0;background:transparent}.company-logo:hover{opacity:.8}@media (max-width: 768px){.project-card{display:flex;flex-direction:column;align-items:center;text-align:center}.project-card h3{text-align:center;width:100%}.project-card p{text-align:center}.project-card a{display:inline-block;padding:.75rem 1.5rem;margin:1rem auto;background:#000;color:#fff;border-radius:8px;text-align:center;min-width:150px;border:2px solid #000000}.project-logo{display:flex;justify-content:center;align-items:center;margin:2rem auto;padding-bottom:0}.company-logo{width:150px;height:150px}.ios-apps{display:flex;justify-content:center;align-items:center;gap:1.5rem;margin-top:1.5rem;flex-wrap:wrap}.app-card{display:flex;flex-direction:column;align-items:center}.app-logo{width:100px;height:100px;object-fit:cover;object-position:center}}@media (max-width: 600px){.project-card a{padding:.6rem 1.2rem;font-size:.95rem;min-width:130px}.company-logo{width:120px;height:120px}.ios-apps{gap:1rem}.app-logo{width:80px;height:80px;object-fit:cover;object-position:center}}@media (max-width: 400px){.project-card{padding:1rem}.company-logo{width:100px;height:100px}.app-logo{width:70px;height:70px;object-fit:cover;object-position:center}.ios-apps{gap:.75rem}}html{overflow-x:hidden;width:100%;margin:0;padding:0}body{overflow-x:hidden;width:100%;margin:0;padding:0;min-width:unset;position:relative}#root{width:100%;max-width:100%;padding:0;overflow-x:hidden;margin-top:0}.app{width:100%;overflow-x:hidden;position:relative}@media (max-width: 768px){#root{padding:0;margin-top:0}h1{font-size:2rem}h2{font-size:1.8rem}.hero-v2{width:100%;overflow:hidden}.hero-v2-grid{background-size:50px 50px}.hero-v2-tagline{font-size:1.2rem;padding:0 1rem}.hero-v2-buttons{flex-direction:column;gap:.75rem;padding:0 1rem}.hero-v2-button{width:100%;max-width:280px;padding:.7rem 1.5rem}.about{width:100%;padding:3rem 1.5rem}.about-content{padding:0 .5rem}.about h2{font-size:2rem;text-align:center}.about p{font-size:1rem;line-height:1.6}.experience{padding:3rem 1rem}.projects{margin:2rem 1rem;padding:1.5rem;width:calc(100% - 2rem)}.projects h2{font-size:2rem}.project-grid{grid-template-columns:1fr;gap:1.5rem}.project-card{min-height:auto;padding:1.25rem}.project-card h3{font-size:1.3rem}.ios-apps{flex-direction:row;justify-content:center;gap:1.5rem}.app-logo{width:80px;height:80px;object-fit:cover;object-position:center}.company-logo{width:140px;height:140px}.app-name{font-size:.95rem}.skills{width:100%;padding:3rem 1rem}.skills h2{font-size:2rem}.skills-grid{grid-template-columns:1fr;gap:1.5rem}.skill-category{padding:1.25rem}.skill-category h3{font-size:1.2rem}.skill-item{font-size:.9rem;padding:.4rem .8rem}.resume{width:100%;padding:3rem 1rem}.resume h2{font-size:2rem}.resume-content{padding:0}.contact{width:100%;padding:3rem 1.5rem}.contact h2{font-size:2rem}.contact-dots-backdrop{width:100%;height:300px}.social-links{flex-direction:column;width:100%;max-width:280px}.social-links a{width:100%;text-align:center}.menu-toggle-label{margin:20px}footer{padding:2rem 1rem;font-size:.85rem}.carousel{width:100%}.carousel-container{padding:0 1rem}.beat-visualizer,.spotify-player{padding:1rem}}@media (max-width: 480px){h1{font-size:1.75rem}h2{font-size:1.5rem}.hero-v2-tagline{font-size:1rem}.hero-v2-button{padding:.6rem 1.2rem;font-size:.95rem}.about p{font-size:.95rem}.project-card h3{font-size:1.2rem}.skill-item{font-size:.85rem;padding:.35rem .7rem}.contact-info p{font-size:1rem}.app-logo{width:70px;height:70px;object-fit:cover;object-position:center}.company-logo{width:120px;height:120px}}@media (max-width: 380px){#root{padding:0}h1{font-size:1.5rem}h2{font-size:1.3rem}.hero-v2-tagline{font-size:.95rem}.hero-v2-button{max-width:240px}.about{padding:2rem 1rem}.projects{margin:1rem .5rem;padding:1rem}.skill-category{padding:1rem}.app-logo{width:60px;height:60px;object-fit:cover;object-position:center}.company-logo{width:100px;height:100px}}@media (max-width: 768px){.hero-v2-grid,.contact-dots-backdrop{max-width:100vw;overflow:hidden}.comet-h-lr,.comet-h-rl,.comet-v-tb,.comet-v-bt{max-width:100vw}img{max-width:100%;height:auto}[style*=width]{max-width:100%!important}section{max-width:100vw;overflow-x:hidden}.about,.experience,.projects,.skills,.resume,.my-things,.photo-gallery,.contact{max-width:100%;box-sizing:border-box}div[class*=container]{max-width:100%;overflow-x:hidden}.hero-v2-grid{left:0;width:100%;height:100%;transform:none;background-size:50px 50px}.comet-h-lr,.comet-h-rl{display:none}.contact-dots-backdrop{left:0;transform:translate(0) translateY(-50%);width:100%}}:root{--font-size-xs: clamp(.75rem, .7rem + .25vw, .875rem);--font-size-sm: clamp(.875rem, .8rem + .375vw, 1rem);--font-size-base: clamp(1rem, .9rem + .5vw, 1.125rem);--font-size-lg: clamp(1.125rem, 1rem + .625vw, 1.25rem);--font-size-xl: clamp(1.25rem, 1.1rem + .75vw, 1.5rem);--font-size-2xl: clamp(1.5rem, 1.25rem + 1.25vw, 2rem);--font-size-3xl: clamp(1.875rem, 1.5rem + 1.875vw, 2.5rem);--font-size-4xl: clamp(2.25rem, 1.75rem + 2.5vw, 3.5rem);--spacing-xs: clamp(.25rem, .2rem + .25vw, .5rem);--spacing-sm: clamp(.5rem, .4rem + .5vw, .75rem);--spacing-base: clamp(1rem, .8rem + 1vw, 1.5rem);--spacing-lg: clamp(1.5rem, 1.2rem + 1.5vw, 2rem);--spacing-xl: clamp(2rem, 1.5rem + 2.5vw, 3rem);--spacing-2xl: clamp(3rem, 2rem + 5vw, 4rem);--container-xs: min(100%, 480px);--container-sm: min(100%, 640px);--container-md: min(100%, 768px);--container-lg: min(100%, 1024px);--container-xl: min(100%, 1280px);--container-2xl: min(100%, 1536px)}h1{font-size:var(--font-size-4xl);line-height:1.1;margin-bottom:var(--spacing-lg)}h2{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-base)}h3{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-base)}p{font-size:var(--font-size-base);line-height:1.6;margin-bottom:var(--spacing-base)}.container{width:100%;margin:0 auto;padding:0 var(--spacing-base);max-width:var(--container-xl)}.hero-v2{min-height:max(100vh,600px);padding:var(--spacing-xl) var(--spacing-base);position:relative;overflow:hidden}.hero-v2-grid{position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100%}.hero-v2-tagline{font-size:var(--font-size-xl);margin:var(--spacing-base) 0 var(--spacing-lg)}.hero-v2-button{padding:clamp(.6rem,.5rem + .5vw,.8rem) clamp(1.2rem,1rem + 1vw,2rem);font-size:var(--font-size-base)}.about{padding:var(--spacing-2xl) var(--spacing-lg);max-width:100%}.about-content{max-width:min(100%,1200px);padding:0 var(--spacing-base)}.about h2{font-size:var(--font-size-3xl)}.about p{font-size:var(--font-size-base)}.projects{margin:var(--spacing-lg) auto;padding:var(--spacing-xl);max-width:min(calc(100% - 2rem),1200px);border-radius:clamp(12px,2vw,20px)}.project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,300px),1fr));gap:var(--spacing-lg)}.project-card{padding:var(--spacing-lg);border-radius:clamp(10px,1.5vw,15px);min-height:clamp(350px,40vh,450px)}.project-card h3{font-size:var(--font-size-xl)}.company-logo{width:clamp(120px,15vw,180px);height:clamp(120px,15vw,180px)}.app-logo{width:clamp(70px,10vw,120px);height:clamp(70px,10vw,120px);object-fit:cover;object-position:center}.skills{margin:var(--spacing-lg) auto;padding:var(--spacing-xl);max-width:min(calc(100% - 2rem),1200px)}.skills-grid{gap:var(--spacing-lg)}.skill-category{padding:var(--spacing-lg);border-radius:clamp(10px,1.5vw,15px)}.skill-category h3{font-size:var(--font-size-xl);margin-bottom:var(--spacing-base)}.skill-item{padding:clamp(.4rem,.3rem + .5vw,.75rem) clamp(.8rem,.6rem + 1vw,1.25rem);font-size:var(--font-size-sm);border-radius:clamp(15px,2vw,20px)}.experience{margin:var(--spacing-lg) auto;padding:var(--spacing-xl);max-width:min(calc(100% - 2rem),1200px)}.logo-grid{gap:clamp(1.5rem,3vw,3rem)}.logo-grid img{height:clamp(50px,8vw,80px)}.my-things{margin:var(--spacing-lg) auto;padding:var(--spacing-xl) var(--spacing-lg);max-width:min(calc(100% - 2rem),1200px)}.things-container{gap:var(--spacing-xl)}.listening-section,.working-section{padding:var(--spacing-lg);border-radius:clamp(12px,1.5vw,16px)}.music-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,250px),1fr));gap:var(--spacing-base)}.music-item{padding:var(--spacing-base);border-radius:clamp(8px,1vw,12px)}.music-image-container,.music-item img{width:clamp(120px,18vw,180px);height:clamp(120px,18vw,180px)}.current-project{padding:var(--spacing-lg);gap:var(--spacing-lg)}.project-image img{width:clamp(200px,30vw,300px)}.photo-gallery{margin:var(--spacing-lg) auto;padding:var(--spacing-xl);max-width:min(calc(100% - 2rem),1200px)}.photo-gallery-grid{display:grid;gap:var(--spacing-base);grid-template-columns:repeat(auto-fit,minmax(min(100%,250px),1fr));grid-auto-rows:clamp(200px,25vw,350px)}.photo-container{padding:clamp(3px,.5vw,4px);border-radius:clamp(10px,1.5vw,15px)}.contact{padding:var(--spacing-2xl) var(--spacing-lg)}.contact h2{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-lg)}.contact-info p{font-size:var(--font-size-base)}.social-links{gap:var(--spacing-lg);margin-top:var(--spacing-base)}.social-links a{padding:clamp(.6rem,.5rem + .5vw,.75rem) clamp(1.2rem,1rem + 1vw,1.5rem);border-radius:clamp(8px,1vw,12px);font-size:var(--font-size-base)}.menu-toggle-label{position:fixed;top:clamp(10px,2vw,20px);left:clamp(10px,2vw,20px);z-index:1000}footer{padding:var(--spacing-lg);font-size:var(--font-size-sm)}@media (min-width: 1920px){:root{--font-size-base: 1.125rem}}@media (max-width: 1536px){.project-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}}@media (max-width: 1280px){.music-grid,.photo-gallery-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 1024px){.hero-v2-buttons{flex-wrap:wrap;justify-content:center}.project-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.current-project{flex-direction:column;text-align:center}}@media (max-width: 768px){.hero-v2-buttons{flex-direction:column;align-items:center}.hero-v2-button{width:min(100%,280px)}.project-grid,.music-grid,.skills-grid{grid-template-columns:1fr}.photo-gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:clamp(150px,30vw,250px)}.social-links{flex-direction:column;align-items:center}.social-links a{width:min(100%,280px)}}@media (max-width: 640px){.about-content{text-align:left}.ios-apps{flex-wrap:wrap;justify-content:center}}@media (max-width: 480px){.photo-gallery-grid{grid-template-columns:1fr;grid-auto-rows:clamp(200px,40vw,300px)}.view-project-button+.view-project-button{margin-left:0;margin-top:var(--spacing-sm)}}@media (max-width: 380px){:root{--font-size-base: .95rem}.hero-v2-button{width:100%;max-width:100%}.social-links a{width:100%}}*{transition:font-size .3s ease,padding .3s ease,margin .3s ease,width .3s ease,height .3s ease}.resizing *{transition:none!important}@container (max-width: 500px){.project-card,.skill-category{padding:var(--spacing-base)}}img{max-width:100%;height:auto;object-fit:cover}.grid-fluid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,250px),1fr));gap:var(--spacing-base)}.max-viewport{max-width:calc(100vw - (var(--spacing-base) * 2))}*{max-width:100%}section{overflow-x:hidden}@keyframes fadeIn{0%{opacity:0;transform:translateY(clamp(10px,2vw,20px))}to{opacity:1;transform:translateY(0)}}@media print{.navbar,.hero-v2,.contact,footer{display:none}body{font-size:12pt;color:#000;background:#fff}}.fullscreen-menu{position:fixed;top:0;left:0;width:100%;height:100vh;background-color:#000;transform:translate(100%);transition:transform .4s ease-in-out;z-index:999;display:flex;align-items:center;justify-content:center;padding:6rem 0;box-sizing:border-box}.aside-list{list-style:none;padding:0;margin:0;text-align:center;display:flex;flex-direction:column;gap:clamp(2rem,5vh,4rem);position:relative;z-index:1}.aside-list li{margin:0}.aside-anchor:after{content:"";position:absolute;bottom:-5px;background-color:#fff;left:50%;transform:translate(-50%);width:0;height:3px;border-radius:3px;transition:width .3s ease-in-out}.aside-anchor:hover:after{width:100%}.aside-anchor{color:#fff;text-decoration:none;font-size:clamp(40px,8vw,80px);position:relative;font-weight:700;display:inline-block;transition:all .3s ease}.aside-anchor:hover{transform:scale(1.05)}input[type=checkbox]{display:none}input[type=checkbox]:checked~.fullscreen-menu{transform:translate(0)}input[type=checkbox]:checked~label .bar{background-color:#fff}input[type=checkbox]:checked~label .top{transform:translateY(11px) rotate(45deg)}input[type=checkbox]:checked~label .bottom{transform:translateY(-11px) rotate(-45deg)}input[type=checkbox]:checked~label .middle{width:0;opacity:0}.middle{margin:0 auto}.menu-toggle-label{top:30px;left:30px;display:inline-block;padding:12px;background-color:#ffffffe6;border:2px solid #000000;border-radius:8px;cursor:pointer;z-index:1000;position:fixed;transition:all .3s ease;box-shadow:0 2px 8px #00000026}.menu-toggle-label:hover{transform:scale(1.05);box-shadow:0 4px 12px #00000040;background-color:#fff}.bar{display:block;background-color:#000;width:32px;height:4px;border-radius:2px;margin:6px 0;transition:background-color .4s ease-in,transform .4s ease-in,width .4s ease-in,opacity .4s ease-in}@media (max-width: 768px){.menu-toggle-label{top:20px;left:20px;padding:10px}.bar{width:28px;height:3.5px;margin:5px 0}.aside-list{gap:clamp(1.5rem,4vh,3rem)}.aside-anchor{font-size:clamp(32px,10vw,60px)}}@media (max-width: 480px){.menu-toggle-label{top:15px;left:15px;padding:8px}.bar{width:24px;height:3px;margin:4px 0}.aside-anchor{font-size:clamp(28px,12vw,50px)}.aside-list{gap:clamp(1rem,3vh,2rem)}}.carousel-container{position:relative;width:100%;padding:2rem 0}.carousel{position:relative;width:100%;height:220px;cursor:pointer;overflow:hidden}.carousel-content{position:relative;width:100%;height:100%;display:flex;justify-content:center;align-items:center}.carousel-image{position:absolute;width:180px;height:180px;border-radius:35px;object-fit:cover;box-shadow:0 4px 12px #0000001a;transition:all .4s ease-in-out;pointer-events:none;border:1px solid rgba(0,0,0,.1)}.carousel-image.center{transform:translate(0) scale(1);opacity:1;z-index:3}.carousel-image.left{transform:translate(-140px) scale(.8);opacity:.5;z-index:2}.carousel-image.right{transform:translate(140px) scale(.8);opacity:.5;z-index:2}.carousel-image.back{transform:translate(0) scale(.6);opacity:0;z-index:1}.carousel-button{position:absolute;top:50%;transform:translateY(-50%);background:#000;color:#fff;border:2px solid #000000;width:40px;height:40px;border-radius:50%;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:2}.carousel-button:hover{background:#fff;color:#000}.carousel-button.prev{left:10px}.carousel-button.next{right:10px}.carousel-dots{position:absolute;bottom:0;left:50%;transform:translate(-50%);display:flex;gap:8px;z-index:4}.carousel-dot{width:8px;height:8px;border-radius:50%;border:1px solid #000000;background:#fff;cursor:pointer;padding:0;transition:all .3s ease}.carousel-dot.active{background:#000;transform:scale(1.2)}.carousel-dot:hover{background:#00000080}.carousel:before,.carousel:after{content:"";position:absolute;top:0;bottom:0;width:50%;z-index:4}.carousel:before{left:0;cursor:w-resize}.carousel:after{right:0;cursor:e-resize}.my-things{padding:6rem 2rem;background-color:transparent;color:#000;width:100%;max-width:1400px;margin:0 auto;box-sizing:border-box}*{box-sizing:border-box}.my-things h2{margin-bottom:4rem;text-align:center;font-size:clamp(2.5rem,5vw,4rem);color:#000;font-weight:700;letter-spacing:-.02em}.things-container{display:flex;flex-direction:column;gap:3rem;width:100%;position:relative;z-index:1}.listening-section,.working-section{background:transparent;padding:2rem 0;width:100%;max-width:100%;box-sizing:border-box}.listening-section h3,.working-section h3{margin-bottom:2rem;text-align:left;color:#000;font-weight:600;font-size:clamp(1.3rem,2.5vw,1.8rem);opacity:.8}.music-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2rem;width:100%;box-sizing:border-box;position:relative;z-index:1}.music-item{background:transparent;padding:1rem;text-decoration:none;color:#000;display:flex;flex-direction:column;align-items:center;text-align:center;height:100%;box-sizing:border-box}.music-item h4{margin-bottom:1rem;color:#000;font-size:1.2rem;height:1.5rem;position:relative;z-index:1;transition:color .3s ease;font-weight:600}.music-item p{margin-top:.5rem;font-weight:500;color:#333;position:relative;z-index:1;transition:color .3s ease}.music-image-container{position:relative;cursor:pointer;width:180px;height:180px;margin:0;z-index:1}.music-item img{width:180px;height:180px;object-fit:cover;border-radius:8px}.music-item:hover img{opacity:.9}.music-info{width:100%;margin-top:1rem;min-height:3.5rem;display:flex;flex-direction:column;align-items:center;position:relative;z-index:1;gap:.25rem}.music-info .title{font-weight:600;font-size:1rem;color:#000;margin:0;transition:color .3s ease}.music-info .artist-name{color:#666;font-size:.9rem;font-weight:400;margin:.25rem 0 0;transition:color .3s ease}.play-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;opacity:0;border-radius:8px}.music-image-container:hover .play-overlay{opacity:1}.play-icon{color:#fff;font-size:2rem;background:#000;width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center}.play-icon:hover{opacity:.8}.spotify-player{width:100%;margin-top:1rem;position:relative;z-index:1}.spotify-player iframe{border-radius:8px}.project-display{display:flex;align-items:center;gap:2rem;background:transparent;padding:2rem 0;margin-top:1.5rem}.project-display img{width:300px;height:auto;border-radius:8px}.project-display:hover img{opacity:.9}.project-image img{width:300px;height:auto;border-radius:8px}.current-project:hover .project-image img{opacity:.9}.project-info{flex:1;position:relative;z-index:1}.project-info h4{color:#000;margin-bottom:1rem;transition:color .3s ease;font-weight:600}.project-info p{color:#333;transition:color .3s ease}.current-project{display:flex;align-items:center;gap:2rem;background:transparent;padding:2rem 0;margin-top:1.5rem}.current-project .project-info h4{color:#000;margin-bottom:1rem;transition:color .3s ease;font-size:1.5rem;font-weight:600}.current-project .project-info p{color:#333;transition:color .3s ease}.view-project-button{display:inline-block;margin-top:1rem;padding:.75rem 1.5rem;background:#000;color:#fff;text-decoration:none;border-radius:6px;border:2px solid #000000;font-weight:600}.view-project-button+.view-project-button{margin-left:.75rem}.view-project-button:hover{background:#fff;color:#000}.view-project-button.disabled{cursor:default;opacity:.7}.view-project-button.disabled:hover{background:#000;color:#fff}.project-link{display:inline-block;margin-top:1rem;padding:.75rem 1.5rem;background:#000;color:#fff;text-decoration:none;border-radius:6px;border:2px solid #000000;font-weight:600}.project-link:hover{background:#fff;color:#000}.beat-visualizer{width:100%;display:flex;justify-content:center;position:relative;z-index:1}@media (max-width: 1024px){.music-grid{grid-template-columns:repeat(2,1fr)}.music-item:after{transform:rotate(0) translate(80px) rotate(0)}@keyframes orbit{0%{transform:rotate(0) translate(80px) rotate(0)}to{transform:rotate(360deg) translate(80px) rotate(-360deg)}}}@media (max-width: 768px){.my-things{padding:4rem 2rem}.music-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}.music-item{padding:1.25rem;display:flex;flex-direction:column;align-items:center;text-align:center;min-height:250px}.music-image-container{width:150px;height:150px;margin:0 auto 1rem;flex-shrink:0}.music-item img{width:150px;height:150px;object-fit:cover;border-radius:8px}.music-info{text-align:center;width:100%;display:flex;flex-direction:column;gap:.5rem}.music-info .title{font-size:.95rem;font-weight:600;line-height:1.3;margin:0}.music-info .artist-name{font-size:.85rem;opacity:.8;margin:0}.project-display{flex-direction:column;text-align:center;gap:1.5rem}.project-display img{width:100%;max-width:280px;margin:0 auto}.current-project{flex-direction:column;text-align:center;gap:1.5rem}.current-project .project-image img{width:100%;max-width:280px;margin:0 auto}.project-name-container{display:flex;flex-direction:column;align-items:center;gap:1rem}.view-project-button{width:200px;text-align:center;margin:0}.view-project-button+.view-project-button{margin-left:0}.spotify-player{padding:0 .5rem}}@media (max-width: 600px){.music-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.music-item{padding:1rem;min-height:220px}.music-image-container{width:130px;height:130px;margin-bottom:.75rem}.music-item img{width:130px;height:130px}.music-info .title{font-size:.85rem;line-height:1.2}.music-info .artist-name{font-size:.8rem}}@media (max-width: 480px){.music-grid{grid-template-columns:1fr;gap:1.5rem}.music-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:1.5rem;min-height:auto}.music-image-container{width:140px;height:140px;margin:0 auto 1rem}.music-item img{width:140px;height:140px}.music-info{text-align:center;width:100%;display:flex;flex-direction:column;gap:.4rem}.music-info .title{font-size:.9rem;font-weight:600;line-height:1.3}.music-info .artist-name{font-size:.8rem;opacity:.8}.project-display img,.current-project .project-image img{max-width:240px}}@media (max-width: 380px){.my-things{padding:3rem 1rem}.music-item{padding:1.25rem;gap:.75rem}.music-image-container{width:120px;height:120px;margin-bottom:.75rem}.music-item img{width:120px;height:120px}.music-info .title{font-size:.85rem;line-height:1.2}.music-info .artist-name{font-size:.75rem}}.beat-visualizer{width:100%;height:80px;margin:2rem 0;display:flex;align-items:flex-end;justify-content:center;gap:2px;padding:0 20px}.beat-visualizer canvas{width:100%!important;height:100%!important;display:block;position:absolute;top:0;left:0}.bar{flex:1;max-width:4px;height:100%;border-radius:4px;transform-origin:bottom;transform:scaleY(.2);position:relative}.bar.playing{animation:wave 1.2s ease-in-out infinite;animation-delay:var(--delay)}@keyframes wave{0%,to{transform:scaleY(.2);filter:brightness(1.2) hue-rotate(0deg)}50%{transform:scaleY(.8);filter:brightness(1.5) hue-rotate(20deg)}}.bar.playing:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:inherit;border-radius:inherit;animation:glow 2s ease-in-out infinite;animation-delay:calc(var(--delay) + .1s)}@keyframes glow{0%,to{opacity:.5;filter:blur(4px) brightness(1)}50%{opacity:.8;filter:blur(6px) brightness(1.3)}}.flat-line{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:calc(100% - 40px);height:2px;opacity:.8;border-radius:1px;transition:all .3s ease}.play-pause-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:#4ade80;font-size:24px;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;transition:opacity .3s ease}.play-pause-btn:hover{opacity:.8}.spotify-player{position:relative;margin-bottom:1rem}.animated-text-container{display:flex;flex-direction:column;align-items:center;font-family:Satoshi,sans-serif;font-size:5rem;font-weight:700;line-height:1.2;margin:4rem 0 1rem;padding:0;text-align:center;width:100%;gap:1rem}.text-with-cursor{display:flex;align-items:baseline;justify-content:center;font-size:5rem;margin:0}.animated-text{color:#000;display:inline-block;min-height:5rem;position:relative;font-weight:700}.custom-cursor{color:#000;font-weight:400;font-size:1em;margin-left:6px;display:inline-block;animation:cursor-blink 1s infinite}.name-text{font-size:5rem;font-weight:800;margin:0;color:#000;opacity:0;animation:fadeIn .5s ease-in forwards;animation-delay:.3s}.hero-text{color:#333;font-size:1.5rem;margin-top:.5rem;font-weight:400}@keyframes gradient{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes cursor-blink{0%,50%{opacity:1}51%,to{opacity:0}}.animated-text{background-size:200% auto;animation:gradient 6s ease infinite}.animated-text .cursor,.animated-text:after,.animated-text>.cursor{color:#000!important;font-weight:400!important}.animated-text-container [class*=cursor],.animated-text-container [data-cursor=true]{color:#000!important}@media (max-width: 768px){.animated-text-container,.name-text,.text-with-cursor{font-size:3rem}.animated-text{min-height:3.5rem}}@media (max-width: 480px){.animated-text-container,.name-text,.text-with-cursor{font-size:2.2rem}.animated-text{min-height:2.5rem}}.hero-v2{height:100vh;position:relative;overflow:hidden;background-color:#fff}.hero-v2-container{height:100%;position:relative}.hero-v2 h1{margin:0;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%);text-align:center;font-size:clamp(60px,10vw,120px);font-weight:700;color:#000}.hero-v2 h1 span{font-size:clamp(20px,3vw,30px);display:block;margin-top:1rem;font-weight:400;color:#333}@media (max-width: 768px){.hero-v2 h1{font-size:clamp(48px,12vw,80px)}.hero-v2 h1 span{font-size:clamp(18px,4.5vw,28px)}}.photo-gallery{padding:6rem 2rem;max-width:1400px;margin:0 auto;background:transparent;color:#000}.photo-gallery h2{margin-bottom:4rem;text-align:center;font-size:clamp(2.5rem,5vw,4rem);color:#000;font-weight:700;letter-spacing:-.02em}.photo-gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,350px);gap:1.5rem;align-items:stretch;justify-content:center;max-width:1300px;margin:0 auto;position:relative;z-index:1}.photo-container.vertical,.photo-container.horizontal{width:100%;height:100%}.photo-container{overflow:hidden;border-radius:12px;background:transparent}.photo-container:hover{opacity:.9}.gallery-photo{width:100%;height:100%;object-fit:cover;object-position:center;border-radius:12px}.photo-container.vertical .gallery-photo{object-position:20% 30%}.photo-container.horizontal .gallery-photo{object-position:center center}@media (max-width: 768px){.photo-gallery{padding:4rem 2rem}.photo-gallery h2{margin-bottom:3rem}.photo-gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,minmax(150px,200px));gap:.75rem;width:100%}.photo-container{width:100%;height:100%;border-radius:10px}.gallery-photo{width:100%;height:100%;object-fit:cover}}@media (max-width: 600px){.photo-gallery{padding:3rem 1.5rem}.photo-gallery h2{margin-bottom:2rem}.photo-gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(3,minmax(120px,150px));gap:.5rem;width:100%;padding:0}.photo-container{width:100%;height:100%;padding:2px;border-radius:8px}.photo-container.vertical,.photo-container.horizontal{grid-row:auto;grid-column:auto}.gallery-photo{width:100%;height:100%;object-fit:cover;border-radius:6px}}@media (max-width: 400px){.photo-gallery{padding:2rem 1rem}.photo-gallery-grid{grid-template-rows:repeat(3,minmax(100px,130px));gap:.4rem}}.experience{padding:6rem 2rem;max-width:1400px;margin:0 auto;background:transparent;color:#000;text-align:center}.experience h2{margin-bottom:4rem;font-size:clamp(2.5rem,5vw,4rem);color:#000;font-weight:700;letter-spacing:-.02em}.logo-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr);justify-items:center;align-items:center;gap:clamp(3rem,8vw,6rem) clamp(4rem,10vw,8rem);max-width:1000px;margin:0 auto}.logo-item{position:relative;display:flex;align-items:center;justify-content:center}.logo-grid img{height:clamp(80px,12vw,140px);width:auto;opacity:.9}.logo-top-left img,.logo-top-right img{height:clamp(65px,10vw,110px)}.logo-bottom-left img{height:clamp(90px,13vw,160px)}.logo-bottom-right img{height:clamp(120px,16vw,220px)}.logo-item:hover img{opacity:1}@media (max-width: 768px){.experience{padding:3rem 1.5rem;margin:3rem auto}.experience h2{margin-bottom:3rem}.logo-grid{gap:clamp(2rem,6vw,4rem) clamp(2rem,6vw,4rem)}}@media (max-width: 480px){.experience{padding:2rem 1rem;margin:2rem auto}.experience h2{margin-bottom:2rem}.logo-grid{gap:clamp(1.5rem,5vw,3rem) clamp(1.5rem,5vw,3rem)}}
