body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{height:100vh;position:relative;text-align:center;width:100vw}.App,body,html{overflow:hidden}body,html{background-color:#000;margin:0;padding:0}.main-screen{background-color:#000;height:100%;overflow:auto;padding-bottom:60px;position:relative;width:100%}.main-screen:after{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='a'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23a)' opacity='.1'/%3E%3C/svg%3E");content:"";height:100%;left:0;opacity:.4;pointer-events:none;position:fixed;top:0;width:100%;z-index:11}.circle{border-radius:50%;filter:blur(20px);mix-blend-mode:screen;position:absolute;transform:translate(-50%,-50%);z-index:5}.blur-overlay{-webkit-backdrop-filter:blur(200px);backdrop-filter:blur(200px);height:100%;left:0;pointer-events:none;position:fixed;top:0;width:100%;z-index:10}.name-container{align-items:center;display:flex;justify-content:flex-start;left:50%;max-width:600px;padding:.5rem 0;position:absolute;top:40px;transform:translateX(-50%);width:40%;z-index:10}.name{color:#fffc;font-family:Helvetica Neue,Arial,sans-serif;font-size:24px;font-weight:300;letter-spacing:1px;margin-right:12px;position:relative;text-align:left;text-transform:lowercase}.status-dot{display:flex;height:.6rem;margin-left:.25rem;position:relative;width:.6rem;z-index:10}.status-pulse{animation:ping 1.5s cubic-bezier(0,0,.2,1) infinite;background-color:#4ade80bf;height:100%;opacity:.7;position:absolute;width:100%;z-index:10}.status-center,.status-pulse{border-radius:9999px;display:inline-flex}.status-center{background-color:#22c55ee6;height:.6rem;position:relative;width:.6rem;z-index:11}@keyframes ping{75%,to{opacity:0;transform:scale(2)}}.content-container{align-items:center;display:flex;flex-direction:column;left:0;margin:0 auto;max-width:600px;padding:1rem;position:relative;right:0;text-align:left;top:50px;width:40%;z-index:20}@media screen and (max-width:768px){.App{overflow-y:auto}.main-screen{padding-bottom:200px}.content-container{padding:1rem;top:20px;width:85%}.name-container{top:25px;width:85%}.name{font-size:20px}}@media screen and (max-width:480px){.content-container{padding:.75rem;top:15px;width:90%}.name-container{top:20px;width:90%}.name{font-size:18px}}.section{margin-top:.5rem}#spotify{margin-top:.25rem}.about-container{margin-top:1rem;opacity:.9;width:100%}.spotify-login{align-items:center;display:flex;flex-direction:column;margin-top:40px}.spotify-login p{font-size:18px;margin-bottom:20px}.spotify-login p,.spotify-login-button{color:#fffc;font-family:Helvetica Neue,Arial,sans-serif;font-weight:300;letter-spacing:1px;text-transform:lowercase}.spotify-login-button{background-color:initial;border:1px solid #ffffff4d;border-radius:20px;cursor:pointer;font-size:14px;padding:10px 20px;transition:all .3s ease}.spotify-login-button:hover{background-color:#ffffff1a;border-color:#ffffff80;transform:translateY(-2px)}.loading{color:#fffc;font-family:Helvetica Neue,Arial,sans-serif;font-size:18px;font-weight:300;letter-spacing:1px;margin-top:40px;text-transform:lowercase}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.timeline-container{margin-top:1rem;padding-left:0}.timeline-item{display:flex;margin-bottom:1rem;position:relative}.timeline-dot-container{align-items:center;display:flex;flex-direction:column;margin-right:1.5rem;position:relative;width:20px}.timeline-dot{background-color:#317039;border-radius:50%;box-shadow:0 0 8px 2px #31703966;height:12px;width:12px;z-index:2}.timeline-line{background-color:#fff3;bottom:-2rem;position:absolute;top:12px;width:1px;z-index:1}.timeline-content{display:flex;flex:1 1;flex-direction:column;padding-top:0}.timeline-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.5rem;width:100%}.timeline-title{display:flex;flex-direction:column;font-size:1rem;font-weight:400;margin:0}.company-name{color:#ffffffe6;font-weight:500;margin-bottom:.25rem;text-transform:lowercase}.title-text{color:#ffffffb3;font-size:.9rem;font-style:italic;font-weight:300;text-transform:lowercase}.timeline-year{color:#fff9;font-size:.9rem;min-width:120px;padding-left:10px;text-align:right;white-space:nowrap}.timeline-description{color:#fff9;font-size:.85rem;line-height:1.4;margin:.25rem 0 0;text-transform:lowercase}.timeline-item:last-child .timeline-line{display:none}.timeline-item:first-child .timeline-dot{background-color:#317039;box-shadow:0 0 8px 2px #31703966}.timeline-item:nth-child(2) .timeline-dot{background-color:#f1be49;box-shadow:0 0 8px 2px #f1be4966}.timeline-item:nth-child(3) .timeline-dot{background-color:#cc4b24;box-shadow:0 0 8px 2px #cc4b2466}.timeline-item:nth-child(4) .timeline-dot{background-color:#4f85a6;box-shadow:0 0 8px 2px #4f85a666}@media screen and (max-width:768px){.timeline-header{flex-direction:column;gap:.5rem}.timeline-year{padding-left:0;text-align:left}.timeline-content,.timeline-meta{width:100%}}.space-y-4>*+*,.space-y-6>*+*{margin-top:1rem}.space-y-2>*+*{margin-top:.5rem}.space-y-1>*+*{margin-top:.25rem}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.gap-1{gap:.25rem}.gap-4{gap:1rem}.rounded-xl{border-radius:.75rem}.overflow-hidden{overflow:hidden}.cursor-default{cursor:default}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-light{font-weight:300}.font-medium{font-weight:500}.opacity-80{opacity:.8}.opacity-60{opacity:.6}.p-4{padding:1rem}.pt-4{padding-top:1rem}.pl-4{padding-left:1rem}.mb-1{margin-bottom:.25rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.w-2{width:.5rem}.h-2{height:.5rem}.w-px{width:1px}.rounded-full{border-radius:9999px}.bg-gray-200{background-color:#e5e7eb33}.dark\:bg-gray-700{background-color:#3741514d}.relative{position:relative}.absolute{position:absolute}.top-0{top:0}.bottom-0{bottom:0}.left-0{left:0}.left-1{left:.25rem}.top-3{top:.75rem}.about-container div,.about-container h2,.about-container p,.about-container span{color:#ffffffe6}.about-container .timeline-line,.about-container .timeline-line:before{background-color:#fff9}@media (min-width:640px){.sm\:grid-cols-\[130px_1fr\]{grid-template-columns:130px 1fr}.sm\:gap-4{gap:1rem}.sm\:p-4{padding:1rem}}.footer{background-color:initial;margin-top:60px;padding:20px 0 60px;position:relative;width:100%;z-index:15}.footer-container{align-items:center;flex-direction:column;gap:15px}.footer-container,.social-links{display:flex;justify-content:center;position:relative}.social-links{flex-wrap:wrap;gap:20px;z-index:16}.social-icon{align-items:center;color:#fff9;display:flex;height:24px;justify-content:center;transition:color .3s ease,transform .2s ease;width:24px}.social-icon svg{height:20px;width:20px}.social-icon:hover{color:#ffffffe6}.copyright{color:#ffffff80;font-size:12px;font-weight:300;letter-spacing:.5px;margin-bottom:20px;position:relative;text-align:center;text-transform:lowercase;z-index:16}.navbar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background-color:#0003;border-bottom:1px solid #ffffff0d;left:0;position:fixed;right:0;top:0;z-index:5}.navbar-container{align-items:center;display:flex;justify-content:flex-end;margin:0 auto;max-width:1200px;padding:1rem 2rem}.navbar-links{display:flex;gap:1.5rem}.nav-link{background:none;border:none;color:#ffffffb3;cursor:pointer;font-size:.9rem;font-weight:300;padding:.5rem 0;position:relative;text-transform:lowercase;transition:color .2s ease}.nav-link:hover{color:#fff}.nav-link:after{background-color:#317039;bottom:0;content:"";height:1px;left:0;position:absolute;transition:width .2s ease;width:0}.nav-link:hover:after{width:100%}@media (max-width:768px){.navbar-container{padding:.75rem .5rem}.navbar-links{gap:.75rem;justify-content:space-between;width:100%}.nav-link{font-size:.8rem}}.floating-current-work{align-items:center;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);background:linear-gradient(135deg,#ffffff1a,#ffffff0d 50%,#ffffff05);border:1px solid #ffffff2e;border-radius:12px;box-shadow:0 8px 32px #0000005e,0 2px 8px #0003,inset 0 1px 0 #ffffff26;cursor:pointer;display:flex;flex-direction:column;overflow:hidden;padding:12px;position:fixed;right:80px;top:35%;transform:translateY(-50%);transition:all .3s cubic-bezier(.25,.8,.25,1);width:160px;z-index:100}.floating-current-work:before{background:linear-gradient(90deg,#0000,#fff6 50%,#0000);content:"";height:1px;left:0;opacity:.8;position:absolute;right:0;top:0}.floating-current-work:after{background:radial-gradient(circle at 30% 20%,#ffffff1a 0,#0000 50%);content:"";height:200%;left:-50%;opacity:.6;pointer-events:none;position:absolute;top:-50%;width:200%}.floating-current-work:hover{background:linear-gradient(135deg,#ffffff2e,#ffffff1a 50%,#ffffff14);border-color:#ffffff4d;box-shadow:0 20px 60px #0006,0 8px 20px #0000004d,inset 0 1px 0 #ffffff40;transform:translateY(calc(-50% - 8px)) scale(1.05)}.floating-current-work:hover:after{opacity:.8}.floating-work-header{align-items:center;display:flex;gap:8px;margin-bottom:16px}.work-status-indicator{animation:pulse-green 2s infinite;background:#22c55e;border-radius:50%;height:8px;width:8px}@keyframes pulse-green{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.work-label{color:#fff9;font-family:Helvetica Neue,Arial,sans-serif;font-size:12px;font-weight:300;letter-spacing:.5px;text-transform:lowercase}.work-content{display:flex;flex-direction:column;gap:12px}.work-title{color:#ffffffe6;font-size:16px;font-weight:400;letter-spacing:.5px;text-transform:lowercase}.work-description,.work-title{font-family:Helvetica Neue,Arial,sans-serif}.work-description{color:#ffffffb3;font-size:11px;font-weight:300;letter-spacing:.3px;line-height:1.4}.work-tech-stack{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.tech-tag{background:#ffffff1a;border:1px solid #ffffff0d;border-radius:8px;color:#fffc;font-family:Helvetica Neue,Arial,sans-serif;font-size:11px;font-weight:300;letter-spacing:.3px;padding:4px 8px;text-transform:lowercase}@media screen and (max-width:1200px){.floating-current-work{padding:10px;right:20px;width:140px}}@media screen and (max-width:768px){.floating-current-work:not(.mobile-expanded){display:none}.floating-current-work.mobile-expanded{bottom:auto!important;display:flex!important;left:auto!important;margin:0!important;max-width:none!important;position:relative!important;right:auto!important;top:auto!important;transform:none!important;width:100%!important}.work-title{font-size:14px}.tech-tag{font-size:10px;padding:3px 6px}}@media screen and (max-width:480px){.floating-current-work:not(.mobile-expanded){display:none}.tech-tag{font-size:9px;padding:2px 5px}}.floating-spotify{align-items:center;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);background:linear-gradient(135deg,#ffffff1a,#ffffff0d 50%,#ffffff05);border:1px solid #ffffff2e;border-radius:12px;box-shadow:0 8px 32px #0000005e,0 2px 8px #0003,inset 0 1px 0 #ffffff26;display:flex;flex-direction:column;overflow:hidden;padding:12px;position:fixed;right:80px;top:65%;transform:translateY(-50%);transition:all .3s cubic-bezier(.25,.8,.25,1);width:160px;z-index:100}.floating-spotify:before{background:linear-gradient(90deg,#0000,#fff6 50%,#0000);content:"";height:1px;left:0;opacity:.8;position:absolute;right:0;top:0}.floating-spotify:after{background:radial-gradient(circle at 30% 20%,#ffffff1a 0,#0000 50%);content:"";height:200%;left:-50%;opacity:.6;pointer-events:none;position:absolute;top:-50%;width:200%}.floating-spotify:hover{background:linear-gradient(135deg,#ffffff2e,#ffffff1a 50%,#ffffff14);border-color:#1db95480;box-shadow:0 20px 60px #0006,0 8px 20px #0000004d,inset 0 1px 0 #ffffff40,0 0 25px #1db95426;transform:translateY(calc(-50% - 8px)) scale(1.05)}.floating-spotify:hover:after{opacity:.8}.spotify-header{align-items:center;display:flex;gap:8px;justify-content:space-between;margin-bottom:4px;margin-bottom:16px}.listening-label{color:#fff9;font-family:Helvetica Neue,Arial,sans-serif;font-size:12px;font-weight:300;letter-spacing:.5px;text-transform:lowercase}.spotify-logo-icon{align-items:center;display:flex;height:12px;justify-content:center;width:12px}.album-img{border-radius:8px;height:100%;object-fit:cover;width:100%}.now-playing-text{color:#ffffffe6;font-family:Helvetica Neue,Arial,sans-serif;font-size:14px;font-weight:600;letter-spacing:.5px}.audio-icon{align-items:center}.album-art-container,.audio-icon{display:flex;justify-content:center}.album-art-container{margin:8px 0}.album-art{align-items:center;background:linear-gradient(135deg,#8b4513,peru);border-radius:10px;display:flex;height:90px;justify-content:center;overflow:hidden;width:90px}.album-placeholder{color:#fff;font-family:Helvetica Neue,Arial,sans-serif;font-size:12px;font-weight:700;letter-spacing:1.5px;text-align:center}.track-details{gap:4px;margin:8px 0;text-align:center}.audio-controls,.track-details{display:flex;flex-direction:column}.audio-controls{gap:10px;margin-top:8px}.progress-container{display:flex;flex-direction:column;gap:6px}.progress-bar{background:#fff3;border-radius:2px;cursor:pointer;height:4px;overflow:hidden;position:relative;width:100%}.progress-fill{background:#1db954;border-radius:2px;height:100%;transition:width .1s linear}.time-display{align-items:center;display:flex;gap:4px;justify-content:center}.current-time,.duration,.time-separator{color:#fff9;font-family:Helvetica Neue,Arial,sans-serif;font-size:10px;font-weight:400;letter-spacing:.3px}.play-button,.player-controls{align-items:center;display:flex;justify-content:center}.play-button{background:#ffffffe6;border:none;border-radius:50%;cursor:pointer;height:32px;outline:none;transition:all .3s ease;width:32px}.play-button:hover{background:#fff;transform:scale(1.05)}.play-icon{color:#000;font-size:12px;margin-left:2px}.track-name{color:#ffffffe6;font-size:16px;font-weight:400;letter-spacing:.5px;line-height:1.3;margin-bottom:2px;text-transform:lowercase}.track-artist,.track-name{font-family:Helvetica Neue,Arial,sans-serif}.track-artist{color:#ffffffb3;font-size:11px;font-weight:300;letter-spacing:.3px}@media screen and (max-width:1200px){.floating-spotify{padding:10px;right:20px;top:calc(50% + 100px);width:140px}.album-art{height:70px;width:70px}.album-placeholder{font-size:10px}}@media screen and (max-width:768px){.floating-spotify:not(.mobile-expanded){display:none}.floating-spotify.mobile-expanded{bottom:auto!important;display:flex!important;left:auto!important;margin:0!important;max-width:none!important;position:relative!important;right:auto!important;top:auto!important;transform:none!important;width:100%!important}.album-art{height:80px;width:80px}.album-placeholder{font-size:12px}.track-name{font-size:14px}.track-artist{font-size:10px}}@media screen and (max-width:480px){.floating-spotify:not(.mobile-expanded){display:none}.album-art{height:70px;width:70px}.track-name{font-size:13px}.track-artist{font-size:9px}.listening-label{font-size:11px}.track-artist{font-size:13px}}.mobile-expanded-overlay,.mobile-floating-bubble{display:none}@media screen and (max-width:768px){.mobile-floating-bubble{align-items:center;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);background:linear-gradient(135deg,#ffffff26,#ffffff14 50%,#ffffff0d);border:1px solid #fff3;border-radius:50%;bottom:20px;box-shadow:0 8px 32px #0000004d,0 2px 8px #0003,inset 0 1px 0 #ffffff26;cursor:pointer;display:flex;height:60px;justify-content:center;position:fixed;right:20px;transition:all .3s cubic-bezier(.25,.8,.25,1);width:60px;z-index:1000}.mobile-floating-bubble:before{background:radial-gradient(circle at 30% 30%,#ffffff1a 0,#0000 60%);border-radius:50%;bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.mobile-floating-bubble:hover{border-color:#ffffff4d;box-shadow:0 12px 40px #0006,0 4px 12px #0000004d,inset 0 1px 0 #ffffff40;transform:scale(1.05)}.bubble-icon{align-items:center;display:flex;flex-direction:column;gap:4px}.bubble-dot{animation:bubble-pulse 2s ease-in-out infinite;background:#ffffffb3;border-radius:50%;height:8px;width:8px}.bubble-dot:nth-child(2){animation-delay:.3s}@keyframes bubble-pulse{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.mobile-expanded-overlay{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1001}.expanded-content{align-items:center;display:flex;flex-direction:column;gap:20px;max-width:320px;position:relative;width:100%}.close-button{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(135deg,#ffffff26,#ffffff14);border:1px solid #fff3;border-radius:50%;color:#fffc;cursor:pointer;display:flex;font-size:24px;font-weight:300;height:40px;justify-content:center;position:absolute;right:10px;top:-10px;transition:all .3s ease;width:40px;z-index:1002}.close-button:hover{background:linear-gradient(135deg,#fff3,#ffffff1f);border-color:#ffffff4d;transform:scale(1.05)}.expanded-components{align-items:center;display:flex;flex-direction:column;gap:20px;width:100%}.expanded-component-wrapper{max-width:280px;width:100%}}@media screen and (max-width:480px){.mobile-floating-bubble{bottom:16px;height:55px;right:16px;width:55px}.bubble-dot{height:7px;width:7px}.expanded-content{max-width:300px}.close-button{font-size:20px;height:36px;width:36px}}
/*# sourceMappingURL=main.5e73b46f.css.map*/