@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}:root{font-family:Satoshi,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#0d1117;min-height:100vh;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#60a5fa;text-decoration:inherit}a:hover{color:#3b82f6}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background-color:#0d1117;background-attachment:fixed}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#60a5fa}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center;position:relative}.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:2rem;text-align:center;position:relative;overflow:hidden}.about{padding:4rem 2rem;max-width:1200px;margin:2rem auto;display:flex;gap:3rem;align-items:center;background-color:transparent;border:1px solid;border-image-slice:1;border-image-source:linear-gradient(to right,rgba(59,130,246,.2),rgba(37,99,235,.1),transparent);border-radius:20px;position:relative;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1)}.about:hover{transform:translateY(-4px);border-image-source:linear-gradient(to right,rgba(59,130,246,.4),rgba(37,99,235,.2),transparent);box-shadow:0 8px 32px #3b82f60d}.about-content{flex:1;text-align:left;position:relative;z-index:1}.about-image{flex:1;display:flex;justify-content:center;position:relative;z-index:1}.headshot{width:250px;height:250px;object-fit:cover;border-radius:15px;box-shadow:0 8px 32px #0000004d;transition:all .4s cubic-bezier(.4,0,.2,1);border:none}.headshot:hover{transform:scale(1.05);box-shadow:0 12px 40px #0006}.about h2{margin-bottom:1.5rem;font-size:2.5rem;color:#fff;transition:color .3s ease}.about:hover h2{color:#60a5fa}.about p{font-size:1.1rem;line-height:1.6;color:#ccc;margin-bottom:1rem;transition:color .3s ease}.about:hover p{color:#e0e0e0}@media (max-width: 768px){.about{flex-direction:column;text-align:center;padding:2rem 1rem}.about-content{text-align:center}}.skills{padding:4rem 2rem;max-width:1200px;margin:2rem auto;background-color:transparent;border:1px solid;border-image-slice:1;border-image-source:linear-gradient(to right,rgba(59,130,246,.2),rgba(37,99,235,.1),transparent);border-radius:20px;color:#fff;position:relative;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1)}.skills:hover{transform:translateY(-4px);border-image-source:linear-gradient(to right,rgba(59,130,246,.4),rgba(37,99,235,.2),transparent);box-shadow:0 8px 32px #3b82f60d}.skills h2{margin-bottom:2rem;text-align:center;font-size:2.5rem;color:#fff;position:relative;z-index:1;transition:transform .3s ease,color .3s ease}.skills h2:hover{transform:translateY(-2px);color:#60a5fa}.skills-grid{display:flex;flex-direction:column;gap:2rem;position:relative;z-index:1}.skill-category{background:#0d111780;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);padding:2rem;border-radius:15px;box-shadow:0 8px 32px #0000004d;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.skill-category:hover{transform:translateY(-4px);border-color:#fff3;box-shadow:0 12px 40px #0006}.skill-category h3{margin-bottom:1rem;color:#fff;font-size:1.5rem;position:relative;z-index:1;transition:color .3s ease}.skill-category:hover h3{color:#60a5fa}.skill-list{display:flex;flex-wrap:wrap;gap:1rem;margin:0;padding:0;list-style:none;position:relative;z-index:1;justify-content:center}.skill-item{background:linear-gradient(135deg,#1a1a1ae6,#141414e6);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);padding:.5rem 1rem;border-radius:20px;border:1px solid rgba(96,165,250,.2);font-size:.9rem;color:#fff;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;cursor:pointer}.skill-item:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(96,165,250,.1),transparent);transition:left .5s ease}.skill-item:hover:before{left:100%}.skill-item:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 8px 24px #3b82f64d;border-color:#60a5fa;color:#60a5fa;background:linear-gradient(135deg,#3b82f61a,#60a5fa0d)}@media (max-width: 768px){.skills{padding:2rem 1rem}}.resume{padding:4rem 2rem;max-width:1200px;margin:0 auto}.resume h2{margin-bottom:2rem;text-align:center;font-size:2.5rem;color:#fff}.resume-content{background:#fff;padding:2rem;border-radius:10px;box-shadow:0 4px 8px #0000001a}.resume-download-link{display:block;text-align:center;margin-top:1rem;width:100%}.resume-download-link a{color:#64b5f6;text-decoration:none;font-weight:500;transition:color .3s ease}.resume-download-link a:hover{color:#3b82f6}@media (max-width: 768px){.resume{padding:2rem 1rem}.resume-content{padding:1rem}}.projects{padding:4rem 2rem;max-width:1200px;margin:2rem auto;background-color:transparent;border:1px solid;border-image-slice:1;border-image-source:linear-gradient(to right,rgba(59,130,246,.2),rgba(37,99,235,.1),transparent);border-radius:20px;color:#fff;position:relative;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1)}.projects:hover{transform:translateY(-4px);border-image-source:linear-gradient(to right,rgba(59,130,246,.4),rgba(37,99,235,.2),transparent);box-shadow:0 8px 32px #3b82f60d}.projects h2{margin-bottom:2rem;text-align:center;font-size:2.5rem;color:#fff;position:relative;z-index:1;transition:transform .3s ease,color .3s ease}.projects h2:hover{transform:translateY(-2px);color:#60a5fa}.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:#0d111780;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);padding:2rem;border-radius:15px;box-shadow:0 8px 32px #0000004d;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;min-height:450px;position:relative;overflow:hidden}.project-card:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,#ffffff0d,#fff0 70%);opacity:0;transition:opacity .5s ease;pointer-events:none;transform:rotate(0)}.project-card:hover:before{opacity:1;animation:rotate-glow 5s linear infinite}@keyframes rotate-glow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.project-card:hover{transform:translateY(-8px);border-color:#fff3;box-shadow:0 12px 40px #0006}.project-card h3{margin-bottom:1rem;color:#fff;font-size:1.5rem;transition:color .3s ease;position:relative;z-index:1}.project-card:hover h3{color:#60a5fa}.project-card p{color:#ccc;margin-bottom:1rem;line-height:1.6;transition:color .3s ease;position:relative;z-index:1}.project-card:hover p{color:#e0e0e0}.project-card a{color:#60a5fa;text-decoration:none;font-weight:500;transition:all .3s ease;margin-bottom:2rem;display:inline-block;position:relative;z-index:1}.project-card a:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:2px;background:linear-gradient(90deg,#60a5fa,#3b82f6);transition:width .3s ease}.project-card a:hover:after{width:100%}.project-card a:hover{color:#3b82f6;transform:translate(4px)}.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;transition:transform .3s cubic-bezier(.4,0,.2,1);border-radius:15px;padding:1rem}.app-card:hover{transform:translateY(-8px) scale(1.05)}.app-logo{width:120px;height:120px;border-radius:22px;margin-bottom:1rem;box-shadow:0 8px 24px #0000004d;transition:all .3s cubic-bezier(.4,0,.2,1)}.app-card:hover .app-logo{box-shadow:0 16px 48px #3b82f633;transform:scale(1.1)}.app-name{font-size:1.1rem;color:#fff;margin-top:.5rem;transition:color .3s ease}.app-card:hover .app-name{color:#60a5fa}.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;-webkit-backdrop-filter:none;backdrop-filter:none;border:none;box-shadow:0 4px 12px #00000026;transition:all .4s cubic-bezier(.4,0,.2,1)}.company-logo:hover{transform:scale(1.08);border-color:none;box-shadow:none}@media (max-width: 600px){.project-card:first-child .project-logo{margin-top:2.5rem;padding-bottom:0}.project-card:first-child a{margin-bottom:2.2rem;display:block}.ios-apps{gap:.7rem;margin-top:1rem}.app-logo{width:90px;height:90px;margin-bottom:.5rem}}.navbar{display:flex;justify-content:space-between;align-items:center;padding:.5rem 2rem;background-color:#0d1117;position:fixed;top:0;left:0;right:0;z-index:1000;height:70px;box-sizing:border-box}.navbar-logo-link{display:flex;align-items:center;text-decoration:none;height:100%}.navbar-logo-link img{display:block;max-height:100%;width:auto}.nav-brand{font-size:1.5rem;font-weight:700;color:#fff}.nav-links{display:flex;align-items:center;list-style:none;margin:0;padding:0;gap:2rem;height:100%}.nav-links li a{color:#fff;text-decoration:none;transition:color .3s ease}.nav-links li a:hover{color:#646cff}@media (max-width: 768px){.navbar{padding:.5rem 1rem}.navbar-logo-link{margin-right:1.5rem}.nav-links{gap:1rem;overflow-x:auto;white-space:nowrap;-ms-overflow-style:none;scrollbar-width:none}.nav-links::-webkit-scrollbar{display:none}}.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 #00000026;transition:all .4s ease-in-out;pointer-events:none}.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:#00000080;color:#fff;border:none;width:40px;height:40px;border-radius:50%;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:background-color .3s ease;z-index:2}.carousel-button:hover{background:#000000b3}.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:none;background:#0003;cursor:pointer;padding:0;transition:all .3s ease}.carousel-dot.active{background:#646cff;transform:scale(1.2)}.carousel-dot:hover{background:#646cff80}.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:4rem 2rem;background-color:transparent;border:1px solid;border-image-slice:1;border-image-source:linear-gradient(to right,rgba(59,130,246,.2),rgba(37,99,235,.1),transparent);color:#fff;width:100%;max-width:1200px;margin:2rem auto;box-sizing:border-box;position:relative;overflow:hidden;border-radius:20px;transition:all .4s cubic-bezier(.4,0,.2,1)}.my-things:hover{transform:translateY(-4px);border-image-source:linear-gradient(to right,rgba(59,130,246,.4),rgba(37,99,235,.2),transparent);box-shadow:0 8px 32px #3b82f60d}*{box-sizing:border-box}.my-things h2{margin-bottom:2rem;text-align:center;font-size:2.5rem;color:#fff;position:relative;z-index:1;transition:transform .3s ease,color .3s ease}.my-things h2:hover{transform:translateY(-2px);color:#60a5fa}.things-container{display:flex;flex-direction:column;gap:3rem;width:100%;position:relative;z-index:1}.listening-section,.working-section{background:#0d111780;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);padding:2rem;border-radius:15px;box-shadow:0 8px 32px #0000004d;width:100%;max-width:100%;overflow:hidden;box-sizing:border-box;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative}.listening-section:before,.working-section:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,#ffffff0d,#fff0 70%);opacity:0;transition:opacity .5s ease;pointer-events:none;transform:rotate(0)}.listening-section:hover:before,.working-section:hover:before{opacity:1;animation:5s linear infinite}.listening-section:hover,.working-section:hover{transform:translateY(-4px);border-color:#fff3;box-shadow:0 12px 40px #0006}.listening-section h3,.working-section h3{margin-bottom:1.5rem;text-align:left;position:relative;z-index:1;transition:color .3s ease}.listening-section:hover h3,.working-section:hover h3{color:#60a5fa}.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:linear-gradient(135deg,#1a1a1ae6,#141414e6);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid rgba(96,165,250,.1);padding:1rem;border-radius:12px;transition:all .4s cubic-bezier(.4,0,.2,1);text-decoration:none;color:#fff;display:flex;flex-direction:column;align-items:center;text-align:center;height:100%;box-sizing:border-box;position:relative;overflow:hidden}.music-item:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(96,165,250,.05) 0%,transparent 50%);opacity:0;transition:opacity .3s ease;pointer-events:none}.music-item:hover:before{opacity:1}.music-item:hover{transform:translateY(-8px) scale(1.02);border-color:#60a5fa4d;box-shadow:0 16px 32px #3b82f633}.music-item h4{margin-bottom:1rem;color:#60a5fa;font-size:1.2rem;height:1.5rem;position:relative;z-index:1;transition:color .3s ease}.music-item:hover h4{color:#3b82f6}.music-item p{margin-top:.5rem;font-weight:500;color:#fff;position:relative;z-index:1;transition:color .3s ease}.music-item:hover p{color:#e0e0e0}.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;box-shadow:0 4px 16px #0000004d;transition:all .3s cubic-bezier(.4,0,.2,1)}.music-item:hover img{box-shadow:0 8px 32px #3b82f64d;transform:scale(1.05)}.music-info{width:100%;margin-top:1rem;min-height:3.5rem;display:flex;flex-direction:column;align-items:center;position:relative;z-index:1}.music-info .title{font-weight:600;font-size:1rem;color:#fff;margin:0;transition:color .3s ease}.music-item:hover .music-info .title{color:#e0e0e0}.music-info .artist-name{color:#888;font-size:.9rem;font-weight:400;margin:.25rem 0 0;transition:color .3s ease}.music-item:hover .music-info .artist-name{color:#a0a0a0}.play-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .3s cubic-bezier(.4,0,.2,1);border-radius:8px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.music-image-container:hover .play-overlay{opacity:1}.play-icon{color:#fff;font-size:2rem;background:linear-gradient(135deg,#60a5fae6,#3b82f6e6);width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1)}.play-icon:hover{transform:scale(1.1);background:linear-gradient(135deg,#3b82f6,#2563eb)}.spotify-player{width:100%;margin-top:1rem;position:relative;z-index:1}.spotify-player iframe{border-radius:8px;box-shadow:0 4px 16px #0000004d;transition:box-shadow .3s ease}.spotify-player:hover iframe{box-shadow:0 8px 32px #3b82f633}.project-display{display:flex;align-items:center;gap:2rem;background:linear-gradient(135deg,#1a1a1ae6,#141414e6);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid rgba(96,165,250,.1);padding:2rem;border-radius:12px;margin-top:1.5rem;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.project-display:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(96,165,250,.05) 0%,transparent 50%);opacity:0;transition:opacity .3s ease;pointer-events:none}.project-display:hover:before{opacity:1}.project-display:hover{transform:translateY(-4px);border-color:#60a5fa4d;box-shadow:0 16px 32px #3b82f633}.project-display img{width:300px;height:auto;border-radius:8px;transition:transform .3s ease;position:relative;z-index:1}.project-display:hover img{transform:scale(1.02)}.project-image img{width:300px;height:auto;border-radius:8px;transition:transform .3s ease;position:relative;z-index:1}.current-project:hover .project-image img{transform:scale(1.02)}.project-info{flex:1;position:relative;z-index:1}.project-info h4{color:#60a5fa;margin-bottom:1rem;transition:color .3s ease}.project-display:hover .project-info h4{color:#3b82f6}.project-info p{color:#fff;transition:color .3s ease}.project-display:hover .project-info p{color:#e0e0e0}.current-project{display:flex;align-items:center;gap:2rem;background:linear-gradient(135deg,#1a1a1ae6,#141414e6);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid rgba(96,165,250,.1);padding:2rem;border-radius:12px;margin-top:1.5rem;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.current-project:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(96,165,250,.05) 0%,transparent 50%);opacity:0;transition:opacity .3s ease;pointer-events:none}.current-project:hover:before{opacity:1}.current-project:hover{transform:translateY(-4px);border-color:#60a5fa4d;box-shadow:0 16px 32px #3b82f633}.current-project .project-info h4{color:#60a5fa;margin-bottom:1rem;transition:color .3s ease}.current-project:hover .project-info h4{color:#3b82f6}.current-project .project-info p{color:#fff;transition:color .3s ease}.current-project:hover .project-info p{color:#e0e0e0}.view-project-button{display:inline-block;margin-top:1rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#60a5fa,#3b82f6);color:#fff;text-decoration:none;border-radius:6px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.view-project-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.view-project-button:hover:before{left:100%}.view-project-button:hover{background:linear-gradient(135deg,#3b82f6,#1e40af);transform:translateY(-2px);box-shadow:0 8px 24px #3b82f666}.project-link{display:inline-block;margin-top:1rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#60a5fa,#3b82f6);color:#fff;text-decoration:none;border-radius:6px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.project-link:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.project-link:hover:before{left:100%}.project-link:hover{background:linear-gradient(135deg,#3b82f6,#1e40af);transform:translateY(-2px);box-shadow:0 8px 24px #3b82f666}.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)}}@media (max-width: 768px){.music-grid{grid-template-columns:1fr}.project-display{flex-direction:column;text-align:center}.project-display img{width:100%;max-width:300px}.music-item img,.music-image-container{width:100%;max-width:250px}.current-project{flex-direction:column;text-align:center}.current-project .project-image img{width:100%;max-width:300px}}.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}:root{--react-pdf-annotation-layer: 1;--annotation-unfocused-field-background: url("data:image/svg+xml;charset=UTF-8,<svg width='1px' height='1px' xmlns='http://www.w3.org/2000/svg'><rect width='100%' height='100%' style='fill:rgba(0, 54, 255, 0.13);'/></svg>");--input-focus-border-color: Highlight;--input-focus-outline: 1px solid Canvas;--input-unfocused-border-color: transparent;--input-disabled-border-color: transparent;--input-hover-border-color: black;--link-outline: none}@media screen and (forced-colors: active){:root{--input-focus-border-color: CanvasText;--input-unfocused-border-color: ActiveText;--input-disabled-border-color: GrayText;--input-hover-border-color: Highlight;--link-outline: 1.5px solid LinkText}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid selectedItem}.annotationLayer .linkAnnotation:hover{-webkit-backdrop-filter:invert(100%);backdrop-filter:invert(100%)}}.annotationLayer{position:absolute;top:0;left:0;pointer-events:none;transform-origin:0 0;z-index:3}.annotationLayer[data-main-rotation="90"] .norotate{transform:rotate(270deg) translate(-100%)}.annotationLayer[data-main-rotation="180"] .norotate{transform:rotate(180deg) translate(-100%,-100%)}.annotationLayer[data-main-rotation="270"] .norotate{transform:rotate(90deg) translateY(-100%)}.annotationLayer canvas{position:absolute;width:100%;height:100%}.annotationLayer section{position:absolute;text-align:initial;pointer-events:auto;box-sizing:border-box;margin:0;transform-origin:0 0}.annotationLayer .linkAnnotation{outline:var(--link-outline)}.textLayer.selecting~.annotationLayer section{pointer-events:none}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a{position:absolute;font-size:1em;top:0;left:0;width:100%;height:100%}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a:hover{opacity:.2;background:#ff0;box-shadow:0 2px 10px #ff0}.annotationLayer .textAnnotation img{position:absolute;cursor:pointer;width:100%;height:100%;top:0;left:0}.annotationLayer .textWidgetAnnotation :is(input,textarea),.annotationLayer .choiceWidgetAnnotation select,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{background-image:var(--annotation-unfocused-field-background);border:2px solid var(--input-unfocused-border-color);box-sizing:border-box;font:calc(9px * var(--scale-factor)) sans-serif;height:100%;margin:0;vertical-align:top;width:100%}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid red}.annotationLayer .choiceWidgetAnnotation select option{padding:0}.annotationLayer .buttonWidgetAnnotation.radioButton input{border-radius:50%}.annotationLayer .textWidgetAnnotation textarea{resize:none}.annotationLayer .textWidgetAnnotation :is(input,textarea)[disabled],.annotationLayer .choiceWidgetAnnotation select[disabled],.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input[disabled]{background:none;border:2px solid var(--input-disabled-border-color);cursor:not-allowed}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:hover{border:2px solid var(--input-hover-border-color)}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation.checkBox input:hover{border-radius:2px}.annotationLayer .textWidgetAnnotation :is(input,textarea):focus,.annotationLayer .choiceWidgetAnnotation select:focus{background:none;border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) :focus{background-image:none;background-color:transparent}.annotationLayer .buttonWidgetAnnotation.checkBox :focus{border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.radioButton :focus{border:2px solid var(--input-focus-border-color);outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after,.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{background-color:CanvasText;content:"";display:block;position:absolute}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{height:80%;left:45%;width:1px}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before{transform:rotate(45deg)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{transform:rotate(-45deg)}.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{border-radius:50%;height:50%;left:30%;top:20%;width:50%}.annotationLayer .textWidgetAnnotation input.comb{font-family:monospace;padding-left:2px;padding-right:0}.annotationLayer .textWidgetAnnotation input.comb:focus{width:103%}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{-webkit-appearance:none;-moz-appearance:none;appearance:none}.annotationLayer .popupTriggerArea{height:100%;width:100%}.annotationLayer .fileAttachmentAnnotation .popupTriggerArea{position:absolute}.annotationLayer .popupWrapper{position:absolute;font-size:calc(9px * var(--scale-factor));width:100%;min-width:calc(180px * var(--scale-factor));pointer-events:none}.annotationLayer .popup{position:absolute;max-width:calc(180px * var(--scale-factor));background-color:#ff9;box-shadow:0 calc(2px * var(--scale-factor)) calc(5px * var(--scale-factor)) #888;border-radius:calc(2px * var(--scale-factor));padding:calc(6px * var(--scale-factor));margin-left:calc(5px * var(--scale-factor));cursor:pointer;font:message-box;white-space:normal;word-wrap:break-word;pointer-events:auto}.annotationLayer .popup>*{font-size:calc(9px * var(--scale-factor))}.annotationLayer .popup h1{display:inline-block}.annotationLayer .popupDate{display:inline-block;margin-left:calc(5px * var(--scale-factor))}.annotationLayer .popupContent{border-top:1px solid rgba(51,51,51,1);margin-top:calc(2px * var(--scale-factor));padding-top:calc(2px * var(--scale-factor))}.annotationLayer .richText>*{white-space:pre-wrap;font-size:calc(9px * var(--scale-factor))}.annotationLayer .highlightAnnotation,.annotationLayer .underlineAnnotation,.annotationLayer .squigglyAnnotation,.annotationLayer .strikeoutAnnotation,.annotationLayer .freeTextAnnotation,.annotationLayer .lineAnnotation svg line,.annotationLayer .squareAnnotation svg rect,.annotationLayer .circleAnnotation svg ellipse,.annotationLayer .polylineAnnotation svg polyline,.annotationLayer .polygonAnnotation svg polygon,.annotationLayer .caretAnnotation,.annotationLayer .inkAnnotation svg polyline,.annotationLayer .stampAnnotation,.annotationLayer .fileAttachmentAnnotation{cursor:pointer}.annotationLayer section svg{position:absolute;width:100%;height:100%;top:0;left:0}.annotationLayer .annotationTextContent{position:absolute;width:100%;height:100%;opacity:0;color:transparent;-webkit-user-select:none;user-select:none;pointer-events:none}.annotationLayer .annotationTextContent span{width:100%;display:inline-block}:root{--react-pdf-text-layer: 1;--highlight-bg-color: rgba(180, 0, 170, 1);--highlight-selected-bg-color: rgba(0, 100, 0, 1)}@media screen and (forced-colors: active){:root{--highlight-bg-color: Highlight;--highlight-selected-bg-color: ButtonText}}[data-main-rotation="90"]{transform:rotate(90deg) translateY(-100%)}[data-main-rotation="180"]{transform:rotate(180deg) translate(-100%,-100%)}[data-main-rotation="270"]{transform:rotate(270deg) translate(-100%)}.textLayer{position:absolute;text-align:initial;top:0;right:0;bottom:0;left:0;overflow:hidden;line-height:1;text-size-adjust:none;forced-color-adjust:none;transform-origin:0 0;z-index:2}.textLayer :is(span,br){color:transparent;position:absolute;white-space:pre;cursor:text;margin:0;transform-origin:0 0}.textLayer span.markedContent{top:0;height:0}.textLayer .highlight{margin:-1px;padding:1px;background-color:var(--highlight-bg-color);border-radius:4px}.textLayer .highlight.appended{position:initial}.textLayer .highlight.begin{border-radius:4px 0 0 4px}.textLayer .highlight.end{border-radius:0 4px 4px 0}.textLayer .highlight.middle{border-radius:0}.textLayer .highlight.selected{background-color:var(--highlight-selected-bg-color)}.textLayer br::selection{background:transparent}.textLayer .endOfContent{display:block;position:absolute;top:100%;right:0;bottom:0;left:0;z-index:-1;cursor:default;-webkit-user-select:none;user-select:none}.textLayer.selecting .endOfContent{top:0}.hiddenCanvasElement{position:absolute;top:0;left:0;width:0;height:0;display:none}.resume-viewer-container{width:100%;max-width:800px;margin:0 auto;overflow:hidden;border-radius:10px;box-shadow:0 4px 8px #0000001a}.resume-document{display:flex;flex-direction:column;align-items:center;overflow:auto;width:100%;max-height:80vh;-webkit-overflow-scrolling:touch}.resume-page{margin-bottom:1rem;box-shadow:0 2px 4px #0000001a}.resume-page canvas{max-width:100%;height:auto!important}.animated-text-container{display:flex;flex-direction:column;align-items:center;font-family:Satoshi,sans-serif;font-size:3.5rem;font-weight:700;line-height:1.2;margin:4rem 0 1rem;padding:0;text-align:center;width:100%}.text-with-cursor{display:flex;align-items:baseline;justify-content:center}.animated-text{background:linear-gradient(90deg,#3b82f6,#60a5fa,#93c5fd);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;display:inline-block;min-height:4rem;position:relative}.custom-cursor{color:#60a5fa;font-weight:400;font-size:1em;margin-left:4px;display:inline-block;animation:cursor-blink 1s infinite}.name-text{font-size:4.5rem;font-weight:800;margin-top:.5rem;color:#fff;opacity:0;animation:fadeIn .5s ease-in forwards;animation-delay:1s}.hero-text{color:#a0a0a0;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 8s ease infinite}.animated-text .cursor,.animated-text:after,.animated-text>.cursor{color:#60a5fa!important;font-weight:400!important}.animated-text-container [class*=cursor],.animated-text-container [data-cursor=true]{color:#60a5fa!important}@media (max-width: 600px){.animated-text-container{font-size:1.5rem;margin:2rem 0 .5rem}.animated-text{min-height:2.2rem;font-size:1.2em}.custom-cursor{font-size:1.2em;margin-left:2px}.name-text{font-size:2.2rem;margin-top:.3rem}.text-with-cursor{align-items:center}}.hero-v2{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;background-color:#0d1117}.hero-v2-container{position:relative;z-index:2;text-align:center;color:#fff}.hero-v2-content{position:relative;z-index:3}.hero-v2-tagline{font-size:1.5rem;margin:1rem 0 2rem;color:#ffffffb3}.hero-v2-buttons{display:flex;justify-content:center;gap:1rem}.hero-v2-button{padding:.8rem 2rem;border-radius:8px;text-decoration:none;font-weight:600;transition:all .3s ease}.hero-v2-button.primary{background-color:#3b82f6;color:#fff}.hero-v2-button.primary:hover{background-color:#2563eb}.hero-v2-button.secondary{background-color:transparent;color:#fff;border:1px solid white}.hero-v2-button.secondary:hover{background-color:#fff;color:#0d1117}.hero-v2-grid{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:300%;height:300%;z-index:1;background-image:linear-gradient(rgba(255,255,255,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.07) 1px,transparent 1px);background-size:60px 60px;animation:pulse 10s ease-in-out infinite}@keyframes pulse{0%{opacity:.3;transform:translate(-50%,-50%) scale(1)}50%{opacity:.5;transform:translate(-50%,-50%) scale(1.05)}to{opacity:.3;transform:translate(-50%,-50%) scale(1)}}.hero-v2-canvas{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}.bullet-h,.bullet-v{position:absolute;z-index:2;opacity:0}.bullet-h{width:150px;height:2px;background:linear-gradient(90deg,transparent 0%,#3b82f6 50%,white 95%);animation:shoot-h 6s linear infinite;box-shadow:0 0 8px #3b82f6;border-radius:1px}.bullet-v{width:2px;height:150px;background:linear-gradient(180deg,transparent 0%,#f59e0b 50%,white 95%);animation:shoot-v 6s linear infinite;box-shadow:0 0 8px #f59e0b;border-radius:1px}.bullet-h:nth-of-type(2){background:linear-gradient(90deg,transparent 0%,#10b981 50%,white 95%);box-shadow:0 0 8px #10b981}.bullet-v:nth-of-type(2){background:linear-gradient(180deg,transparent 0%,#ef4444 50%,white 95%);box-shadow:0 0 8px #ef4444}@keyframes shoot-h{0%{transform:translate(-150px);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translate(120vw);opacity:0}}@keyframes shoot-v{0%{transform:translateY(-150px);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(120vh);opacity:0}}.mobile-only{display:none}@media (max-width: 600px){.hero-v2-grid{width:100vw;height:100vh}.mobile-only{display:block}.bullet-v{height:80px;min-height:80px;max-height:80px}.bullet-v.mobile-only{animation:shoot-v-mobile 4s linear infinite}}@keyframes shoot-v-mobile{0%{transform:translateY(-80px);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(100vh);opacity:0}}.photo-gallery{padding:4rem 2rem;max-width:1200px;margin:2rem auto;background-color:transparent;border:1px solid;border-image-slice:1;border-image-source:linear-gradient(to right,rgba(59,130,246,.2),rgba(37,99,235,.1),transparent);border-radius:20px;color:#fff;position:relative;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1)}.photo-gallery:hover{transform:translateY(-4px);border-image-source:linear-gradient(to right,rgba(59,130,246,.4),rgba(37,99,235,.2),transparent);box-shadow:0 8px 32px #3b82f60d}.photo-gallery h2{margin-bottom:2rem;text-align:center;font-size:2.5rem;color:#fff;position:relative;z-index:1;transition:transform .3s ease,color .3s ease}.photo-gallery h2:hover{transform:translateY(-2px);color:#60a5fa}.photo-gallery-grid{display:grid;grid-template-columns:2fr 3fr;grid-template-rows:300px 300px;gap:1.5rem;align-items:stretch;justify-content:center;max-width:800px;margin:0 auto;position:relative;z-index:1}.photo-container.vertical{grid-row:1 / -1}.photo-container{overflow:hidden;border-radius:15px;border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #0000004d;transition:all .4s cubic-bezier(.4,0,.2,1)}.horizontal{flex:1}.photo-container:hover{transform:translateY(-8px) scale(1.02);border-color:#60a5fa4d;box-shadow:0 16px 64px #3b82f633}.gallery-photo{width:100%;height:100%;object-fit:cover;object-position:center;transition:none}.photo-container.vertical .gallery-photo{object-position:20% 30%}.photo-container.horizontal .gallery-photo{object-position:center center}@media (max-width: 600px){.photo-gallery{padding:1.2rem .2rem;margin:1rem .1rem;border-radius:10px}.photo-gallery h2{font-size:1.2rem;margin-bottom:.7rem}.photo-gallery-grid{display:grid;grid-template-columns:1.1fr 1.7fr;grid-template-rows:120px 120px;gap:.5rem;max-width:100vw;min-width:0}.photo-container.vertical{grid-row:1 / 3;grid-column:1 / 2;height:100%;max-height:260px}.photo-container.horizontal{grid-column:2 / 3;max-height:120px}.photo-container{border-radius:6px;min-height:0}.gallery-photo{min-height:0;max-height:100%;height:100%;object-fit:cover}}.experience{padding:1rem 2rem 4rem;max-width:1200px;margin:2rem auto;background-color:transparent;border:1px solid;border-image-slice:1;border-image-source:linear-gradient(to right,rgba(59,130,246,.2),rgba(37,99,235,.1),transparent);border-radius:20px;color:#fff;text-align:center;position:relative;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1)}.experience:hover{transform:translateY(-4px);border-image-source:linear-gradient(to right,rgba(59,130,246,.4),rgba(37,99,235,.2),transparent);box-shadow:0 8px 32px #3b82f60d}.experience h2{margin-bottom:1.5rem;font-size:2rem;color:#fff;position:relative;z-index:1;transition:transform .3s ease,color .3s ease}.experience h2:hover{transform:translateY(-2px);color:#60a5fa}.logo-grid{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:3rem;position:relative;z-index:1}.logo-grid img{height:80px;opacity:.8;transition:all .3s cubic-bezier(.4,0,.2,1);border-radius:8px;padding:.5rem}.logo-grid img:hover{opacity:1;transform:translateY(-4px) scale(1.05);box-shadow:0 8px 24px #3b82f633}
