:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;cursor:none}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:none;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.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}header{position:fixed;top:0;left:0;width:100vw;padding:1rem 0;z-index:1000}nav{display:flex;align-items:center;justify-content:center;gap:2rem;position:relative}.nav-left{margin-right:auto}.main-content{padding-top:4.5rem;flex:1}.home-flex{display:flex;align-items:flex-start;justify-content:space-between;gap:2rem}.home-left{flex:2;text-align:left}.home-right{flex:1;display:flex;justify-content:flex-end;align-items:flex-start}.headshot-img{max-width:500px;border-radius:12px;box-shadow:0 4px 16px #00000085}:root{--bg-color: white;--text-color: black;--alt-bg-color:#FFE6AB;--desc-bg-color: #ABC5FF;--border:black;--footer-bg-color: #d9d9d9;--reverse-background: black;--reverse-text: white}.dark-mode{--bg-color: #242424;--text-color: white;--alt-bg-color: black;--desc-bg-color: #2f2f2f;--border:white;--footer-bg-color: #333;--reverse-background: white;--reverse-text: black}body{background-color:var(--bg-color);color:var(--text-color);transition:background-color .4s cubic-bezier(.4,0,.2,1),color .4s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;height:100%;margin:0}.theme-toggle{width:32px;height:32px;background-color:#333;border-radius:50%;position:relative;cursor:none;transition:background-color .3s ease;display:flex;align-items:center;justify-content:center;margin-right:1rem;margin-left:1rem;overflow:hidden}.theme-toggle.nav-left{position:absolute;left:0;top:50%;transform:translateY(-50%);margin-right:0}.theme-toggle .toggle-icon{width:24px;height:24px;position:absolute;left:4px;top:4px;margin:0;vertical-align:middle}.theme-toggle .toggle-circle{display:none}body.dark-mode .theme-toggle{background-color:#fff}body.dark-mode .theme-toggle .toggle-circle{transform:translate(25px)}footer{background:var(--footer-bg-color);transition:background-color .4s cubic-bezier(.4,0,.2,1),color .4s cubic-bezier(.4,0,.2,1);padding:1rem 0;position:absolute;bottom:auto;left:0;width:100%}.email{text-decoration:underline;color:var(--text-color)}.email:hover{color:#0056b3}.social-links{display:flex;gap:.5rem;justify-content:right;margin-top:.5rem;margin-right:1rem}.popup-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:2000}.popup-content{background:var(--bg-color);color:var(--text-color);padding:2rem;border-radius:12px;box-shadow:0 4px 20px #0000004d;max-width:400px;width:90%;text-align:center;animation:popup-fade .3s ease}.popup-content h2{margin-top:0}.popup-content button{margin-top:1rem;padding:.5rem 1rem;border:none;border-radius:8px;background-color:#007bff;color:#fff;transition:background-color .3s ease}.popup-content button:hover{background-color:#0056b3}@keyframes popup-fade{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.contact-button{display:flex;justify-content:left;border:#0056b3;border-radius:6px;background:#0056b3;color:var(--text-color);transition:background-color .3s ease;margin-top:-5px;position:absolute;left:0;margin-left:2rem}.text-box{border:2px solid var(--border);border-radius:6px;background:var(--desc-bg-color);color:var(--text-color);padding:.5rem;margin-top:.5rem;width:calc(100% - 1rem);box-sizing:border-box;transition:background-color .4s cubic-bezier(.4,0,.2,1),color .4s cubic-bezier(.4,0,.2,1)}button:disabled{background-color:#888;opacity:.6}.submit-button{border:#0056b3;border-radius:6px;background:#0056b3;color:#fff;transition:background-color .3s ease;margin-top:1rem;margin-right:1rem}.nav-link{color:var(--text-color);text-decoration:none;font-weight:700;font-size:2rem;padding:.25rem .75rem;display:inline-block;outline:none;background-color:transparent}.nav-link:focus,.nav-link:hover{outline:none;box-shadow:none;background-color:transparent;text-decoration:none}.nav-link.no-hover-highlight:hover{background-color:transparent}.footer-content{width:100vw;min-width:100vw;left:0;right:0;position:fixed;bottom:0;box-sizing:border-box;text-align:center;background:var(--footer-bg-color);color:var(--text-color);z-index:100}.loader{border:6px solid #f3f3f3;border-top:6px solid #3498db;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}body{cursor:none}.navbar{background-color:#333;padding:1rem;display:flex;gap:1rem;position:fixed;top:0;left:0;right:0;z-index:1000}.nav-link{color:var(--text-color);text-decoration:none;font-weight:700;padding:.5rem 1rem;transition:background-color .3s;position:relative}.nav-link:not(:last-child):after{content:"";position:absolute;right:0;top:25%;height:50%;width:1px;background-color:#777}.nav-link:hover{background-color:#555;border-radius:4px}.home-content{text-align:center;padding:2rem}.home-content h1{font-size:2.5rem;margin-bottom:1rem}.home-content p{font-size:1.2rem;color:#555}.home-content button{margin-top:1rem;padding:.5rem 1.5rem;font-size:1rem;cursor:none;background-color:#4caf50;color:#fff;border:none;border-radius:5px}.home-content button:hover{background-color:#45a049}.zoom:hover{transform:scale(1.5)}.skills-section{display:inline-block;flex-direction:column;align-items:center;justify-content:center;border:2px solid var(--border);border-radius:16px;background:var(--alt-bg-color);color:var(--text-color);padding:2rem;box-shadow:0 2px 12px #00000012;margin-top:2rem;margin-bottom:50px;transition:background-color .4s cubic-bezier(.4,0,.2,1),color .4s cubic-bezier(.4,0,.2,1);max-width:800px}.skills-section h1{text-align:center;margin-bottom:2rem}.skills-section img{transition:transform .2s;cursor:none}.skills-section img:hover{transform:scale(1.5)}.skills-row{display:flex;justify-content:center;gap:50px;margin-bottom:2rem}.home-intro{font-size:3rem;margin-bottom:1rem;font-weight:700;color:#000;transition:color .4s cubic-bezier(.4,0,.2,1)}.about-me-text{font-size:12rem;min-height:auto;max-width:800px;margin:0 auto;color:var(--text-color);transition:color .4s cubic-bezier(.4,0,.2,1)}.skill-logo{padding:6px 12px;margin:0 8px;border-radius:6px;text-decoration:none;display:inline-block;background-color:transparent}.resume-link{text-decoration:none;color:var(--text-color);margin-top:1rem;border:2px solid var(--text-color);padding:.5rem 1rem;border-radius:5px;background-color:#0056b3;transition:background-color .3s ease}.resume-link:hover{background-color:#004494;color:#fff}.text-type{display:inline-block;white-space:pre-wrap}.text-type__cursor{margin-left:.25rem;display:inline-block;opacity:1;color:var(--text-color)}.text-type__cursor--hidden{display:none}.scroll-reveal{margin:20px 0}.scroll-reveal-text{font-size:clamp(1rem,2vw,4rem);line-height:1.5;font-weight:600}.word{display:inline-block}.logoloop{position:relative;overflow-x:hidden;--logoloop-gap: 32px;--logoloop-logoHeight: 28px;--logoloop-fadeColorAuto: var(--background-color)}.logoloop--scale-hover{padding-top:calc(var(--logoloop-logoHeight) * .1);padding-bottom:calc(var(--logoloop-logoHeight) * .1)}@media (prefers-color-scheme: dark){.logoloop{--logoloop-fadeColorAuto: var(--background-color)}}.logoloop__track{display:flex;width:max-content;will-change:transform;-webkit-user-select:none;user-select:none}.logoloop__list{display:flex;align-items:center}.logoloop__item{flex:0 0 auto;margin-right:var(--logoloop-gap);font-size:var(--logoloop-logoHeight);line-height:1}.logoloop__item:last-child{margin-right:var(--logoloop-gap)}.logoloop__node{display:inline-flex;align-items:center}.logoloop__item img{height:var(--logoloop-logoHeight);width:auto;display:block;object-fit:contain;image-rendering:-webkit-optimize-contrast;-webkit-user-drag:none;pointer-events:none;transition:transform .3s cubic-bezier(.4,0,.2,1)}.logoloop--scale-hover .logoloop__item{overflow:visible}.logoloop--scale-hover .logoloop__item:hover img,.logoloop--scale-hover .logoloop__item:hover .logoloop__node{transform:scale(1.2);transform-origin:center center}.logoloop--scale-hover .logoloop__node{transition:transform .3s cubic-bezier(.4,0,.2,1)}.logoloop__link{display:inline-flex;align-items:center;text-decoration:none;border-radius:4px;transition:opacity .2s ease}.logoloop__link:hover{opacity:.8}.logoloop__link:focus-visible{outline:2px solid currentColor;outline-offset:2px}.logoloop--fade:before,.logoloop--fade:after{content:"";position:absolute;top:0;bottom:0;width:clamp(24px,8%,120px);pointer-events:none;z-index:1}.logoloop--fade:before{left:0;background:linear-gradient(to right,var(--logoloop-fadeColor, var(--logoloop-fadeColorAuto)) 0%,rgba(0,0,0,0) 100%)}.logoloop--fade:after{right:0;background:linear-gradient(to left,var(--logoloop-fadeColor, var(--logoloop-fadeColorAuto)) 0%,rgba(0,0,0,0) 100%)}@media (prefers-reduced-motion: reduce){.logoloop__track{transform:translateZ(0)!important}.logoloop__item img,.logoloop__node{transition:none!important}}.target-cursor-wrapper{position:fixed;top:0;left:0;width:0;height:0;pointer-events:none;z-index:9999;transform:translate(-50%,-50%)}.target-cursor-dot{position:absolute;left:50%;top:50%;width:4px;height:4px;background:var(--reverse-background);border-radius:50%;transform:translate(-50%,-50%);will-change:transform}.target-cursor-corner{position:absolute;left:50%;top:50%;width:12px;height:12px;border:3px solid var(--reverse-background);will-change:transform}.corner-tl{transform:translate(-150%,-150%);border-right:none;border-bottom:none}.corner-tr{transform:translate(50%,-150%);border-left:none;border-bottom:none}.corner-br{transform:translate(50%,50%);border-left:none;border-top:none}.corner-bl{transform:translate(-150%,50%);border-right:none;border-top:none}.projects-header{position:absolute;top:80px;left:100px;margin:0rem;font-size:4rem}.project-title{position:absolute;left:clac(2rem+5px);margin:0;font-size:3rem;font-weight:700;z-index:100}.projects-content{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0rem;position:relative;margin:8rem 2rem 2rem}.projects-display{position:absolute;top:0;right:0;display:flex;flex-direction:column;align-items:flex-end;justify-content:flex-start}.project-display{display:flex;flex-direction:row;align-items:flex-start;justify-content:space-between;gap:2rem;border:2px solid var(--border);border-radius:16px;background:var(--alt-bg-color);padding:2rem;box-shadow:0 2px 12px #00000012;transition:background-color .4s cubic-bezier(.4,0,.2,1),color .4s cubic-bezier(.4,0,.2,1);margin-bottom:2.5rem;max-width:100%}.project-description{min-width:200px;width:400px;max-width:100%;word-wrap:break-word;text-align:left;margin-top:5rem;border:2px solid var(--border);border-radius:16px;background:var(--desc-bg-color);padding:2rem;box-shadow:0 2px 12px #00000012;transition:background-color .4s cubic-bezier(.4,0,.2,1),color .4s cubic-bezier(.4,0,.2,1)}.project-video{display:flex;flex-direction:column;align-items:center;margin-top:2.5rem;gap:auto}.project-video video{border-radius:12px;max-width:100%}.project-language{display:flex-end;flex-wrap:nowrap;justify-content:center;font-size:1.2rem;color:#555;font-weight:700;align-self:center;align-items:flex-end;position:relative;top:1.5rem;left:50%;transform:translate(-50%)}.experience-header{position:absolute;top:80px;left:100px;margin:0rem;font-size:4rem}.experience-content{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0rem;position:relative;margin:8rem 2rem 2rem}.experience-display{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;border:2px solid var(--border);margin-bottom:2rem;padding-left:2rem;padding-right:2rem;border-radius:16px;background:var(--alt-bg-color);transition:background-color .4s cubic-bezier(.4,0,.2,1),color .4s cubic-bezier(.4,0,.2,1);width:100%}.experience-logo{position:absolute;top:1rem;right:1rem;width:75px;height:auto;margin-bottom:1rem;border-radius:10px}.experience-title{font-size:3rem;margin-bottom:.5rem}.experience-subtitle{font-size:1.2rem;margin-bottom:1rem;font-weight:700}.experience-description{font-size:1.1rem;line-height:1.6;list-style-type:disc;text-align:center;margin-bottom:1.5rem}.cursor-target:hover{cursor:none}.header{background-color:rgba(var(--bg-color),.6);color:var(--text-color);width:100%;z-index:1000;opacity:.95;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(10px)}.header-link{text-decoration:none;color:var(--bg-color);padding:8px 16px;background-color:var(--text-color);border-radius:8px;box-shadow:0 2px 8px #0000000f;border:2px solid var(--bg-color);transition:border-color .3s,box-shadow .3s}.header-link:hover{border-color:var(--highlight-color)}
