.projects-grid{display:grid;grid-template-columns:repeat(3,minmax(220px,1fr));grid-gap:2rem;gap:2rem;max-width:950px;margin:0 auto}.project-card{display:flex;flex-direction:column;justify-content:flex-start;background-color:#2b2b32;border-radius:10px;padding:1rem;color:white;transition:box-shadow .3s ease,transform .3s ease;transform:translateY(0);height:440px;min-height:440px;max-height:440px;overflow:hidden}.project-card:hover{transform:scale(1.02)}.project-projects{width:100%;height:180px;object-fit:cover;border-radius:6px;margin-bottom:1rem;display:block}.project-title{margin:0 0 .5rem;font-size:1rem;font-weight:700}.project-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0 .75rem;max-height:60px;overflow-y:auto;align-content:flex-start;scrollbar-width:none}.project-tags::-webkit-scrollbar{display:none}.project-spacer{flex-grow:1}.project-card-content{margin-bottom:.5rem}.project-description{font-size:.9rem;margin-bottom:1rem}.project-card-footer{margin-top:auto}.project-links{display:flex;gap:.4rem;margin-top:.5rem}.project-button{background:#fff;color:#111;border:2px solid #111;border-radius:8px;padding:.5rem .7rem;font-size:.8rem;font-family:inherit;box-shadow:none;transition:background .15s,color .15s;outline:none;cursor:pointer;text-decoration:none;margin:0;display:inline-block}.project-button:hover{background:#111;color:#fff;border-color:#111}.dark-mode .project-button{background:#111;color:#fff;border:2px solid #fff}.dark-mode .project-button:hover{background:#fff;color:#111;border-color:#fff}.skill-tag{display:inline-flex;align-items:center;border-radius:.2em;font-size:.7em;font-weight:500;padding:.3em .95em .3em .65em;white-space:nowrap;background:#23232b;color:#fff}.skill-icon-projects,.skill-tag-text{vertical-align:middle;display:inline-block}.skill-icon-projects{width:18px!important;height:18px!important;margin-right:.39em;object-fit:contain}.light-mode .skill-tag{background:#e8e8f3;color:#232232;box-shadow:0 1px 5px 0 rgba(180,180,180,.07)}.fancy-underline{position:relative;text-decoration:none;color:inherit;cursor:pointer;display:inline-block}.fancy-underline:after{content:"";position:absolute;left:0;bottom:0;width:100%;height:2px;background-color:#2081e2;pointer-events:none;transform:scaleX(1);transform-origin:center;transition:transform .3s cubic-bezier(.4,0,.2,1)}.fancy-underline:hover:after{transform:scaleX(0)}.about-photo-grid{column-count:3;column-gap:2rem;max-width:950px;margin:0 auto}.about-photo-block{display:inline-block;width:100%;margin-bottom:2rem;page-break-inside:avoid;break-inside:avoid;text-align:center;position:relative}.about-photo-block img{width:100%;height:auto;display:block;border-radius:12px;object-fit:cover;box-shadow:0 4px 12px rgba(0,0,0,.1)}.about-photo-block p{margin-top:.75rem;font-size:1rem;line-height:1.6;color:var(--text-dark)}.dark-mode .about-photo-block p{color:#ffffff}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent!important}::-webkit-scrollbar-thumb{background-color:rgba(128,128,128,.5);border-radius:4px;-webkit-transition:background-color .3s ease;transition:background-color .3s ease;background-clip:content-box;border:2px solid transparent}::-webkit-scrollbar-thumb:hover{background-color:rgba(128,128,128,.8)}html{scrollbar-width:thin;scrollbar-color:rgba(128,128,128,.5) transparent}.light-mode ::-webkit-scrollbar,.light-mode ::-webkit-scrollbar-track{background:transparent!important}.light-mode ::-webkit-scrollbar-thumb{background-color:rgba(50,50,50,.3)}.light-mode ::-webkit-scrollbar-thumb:hover{background-color:rgba(50,50,50,.6)}.light-mode html{scrollbar-color:rgba(50,50,50,.3) transparent}.dark-mode ::-webkit-scrollbar,.dark-mode ::-webkit-scrollbar-track{background:transparent!important}.dark-mode ::-webkit-scrollbar-thumb{background-color:rgba(200,200,200,.3)}.dark-mode ::-webkit-scrollbar-thumb:hover{background-color:rgba(200,200,200,.6)}.dark-mode html{scrollbar-color:rgba(200,200,200,.3) transparent}.experiences-grid{display:flex;flex-direction:column;gap:2rem;align-items:center;max-width:700px;margin:0 auto}.experiences-entry{width:100%;max-width:700px;background-color:#2b2b32;padding:1.5rem;border-radius:12px;box-sizing:border-box;transition:background-color .3s ease,transform .2s ease;position:relative}.experiences-entry:hover{transform:scale(1.02)}.experience-icon{position:absolute;top:10px;right:10px;width:60px;height:60px;border-radius:8px}.education-grid{display:flex;flex-direction:column;gap:2rem;align-items:center;max-width:700px;margin:0 auto}.education-entry{width:100%;max-width:700px;background-color:#2b2b32;padding:1.5rem;border-radius:12px;box-sizing:border-box;transition:background-color .3s ease,transform .2s ease;position:relative}.education-entry:hover{transform:scale(1.02)}.education-icon{position:absolute;top:10px;right:10px;width:60px;height:60px;border-radius:8px}.education-entry ul{list-style:none;padding-left:1.5rem}.education-entry ul li{position:relative;padding-left:1.5rem;margin-bottom:.5rem}.education-entry ul li:before{content:"";position:absolute;left:0;top:.25rem;width:12px;height:12px;background-image:url(/assets/icons/bullet-dark.png);background-size:cover;background-repeat:no-repeat}html[data-theme=light] .education-entry ul li:before{background-image:url(/assets/icons/bullet-light.png)}.desktop-only{display:inline}.mobile-only{display:none}.intro-left{width:100%;display:flex;justify-content:center}.intro-image{border-radius:.5rem;max-width:100%;height:auto}.intro-name{font-size:2.25rem;font-weight:700;margin-bottom:1rem;white-space:nowrap}.intro-left,.intro-right{width:50%}.intro-right{margin-top:0;width:100%;padding:0 1rem}.intro-container{display:flex;flex-direction:row;justify-content:center;align-items:center;gap:3rem;padding:9rem 2rem;max-width:1200px;margin:0 auto}*,.intro-container,:after,:before{box-sizing:border-box}.intro-left{width:400px;height:400px;position:relative;margin-top:50px}:root{--background-dark:#181c20;--text-dark:white;--hover-dark:rgba(255,255,255,0.3);--background-light:#ffffff;--text-light:black;--hover-light:rgba(0,0,0,0.3);--header-bg-light:rgba(255,255,255,0.7);--header-bg-dark:rgba(20,20,20,0.85);--header-bg:var(--header-bg-dark)}.light-mode{--background:var(--background-light);--text:var(--text-light);--hover:var(--hover-light);--header-bg:var(--header-bg-light)}.dark-mode{--background:var(--background-dark);--text:var(--text-dark);--hover:var(--hover-dark);--header-bg:var(--header-bg-dark)}body{font-family:Georgia,sans-serif;margin:0;padding:0;background-color:var(--background);transition:background-color .3s ease,color .3s ease;overflow-y:auto;overflow-x:hidden}.container{max-width:1000px;margin:0 auto;padding:0 1rem}a img{vertical-align:middle}section{scroll-margin-top:110px}.intro-section{min-height:100vh;padding:2rem 0}.intro-section,.intro-section>.container{display:flex;align-items:center;justify-content:center;box-sizing:border-box}.intro-section>.container{flex-direction:row;flex-wrap:wrap;gap:60px;width:100%;max-width:1200px;margin:0 auto;padding:0 2rem}.intro-left,.intro-right{flex:0 1 45%;max-width:550px;min-width:300px;display:flex;justify-content:center;align-items:center}.intro-right{flex-direction:column;align-items:flex-start;text-align:left}.intro-right h1{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.intro-right p{font-size:1.1rem;line-height:1.6;margin-bottom:.5rem;color:inherit}#email{font-size:1.1rem;color:white;text-decoration:none;cursor:pointer;transition:color .3s ease}#three-canvas{width:100%;height:80vh;max-height:600px;display:block;background-color:transparent}.centered-heading{font-size:2.75rem;font-weight:600;margin-bottom:40px;text-align:center}.skills-grid-section{padding:2rem 1rem;text-align:left}.skills-grid-icons{display:grid;grid-template-columns:repeat(6,1fr);grid-gap:2rem;gap:2rem;justify-items:center;align-items:center;max-width:1000px}.skills-grid-icons img{width:100px;height:100px;transition:transform .3s ease}.skills-grid-icons img:hover{transform:scale(1.1)}main>section{margin-bottom:200px}main>section:last-child{margin-bottom:0}header{position:fixed;top:0;left:0;right:0;height:100px;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background-color:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none;transition:background-color .3s ease,padding .3s ease,box-shadow .3s ease,-webkit-backdrop-filter .3s ease;transition:background-color .3s ease,padding .3s ease,backdrop-filter .3s ease,box-shadow .3s ease;transition:background-color .3s ease,padding .3s ease,backdrop-filter .3s ease,box-shadow .3s ease,-webkit-backdrop-filter .3s ease}header.scrolled{transition:background-color .3s ease,box-shadow .3s ease,-webkit-backdrop-filter .3s ease;transition:background-color .3s ease,backdrop-filter .3s ease,box-shadow .3s ease;transition:background-color .3s ease,backdrop-filter .3s ease,box-shadow .3s ease,-webkit-backdrop-filter .3s ease;background-color:var(--header-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 8px rgba(0,0,0,.05)}.header-left{gap:15px;font-size:15px;transition:opacity .3s ease}.header-right{justify-content:flex-end;flex:1 1}.header-center,.header-right{display:flex;align-items:center}.header-center{justify-content:space-between;gap:60px}.header-icons{display:flex;gap:20px}.header-inner{justify-content:space-between;width:100%;max-width:1000px;margin:0 auto;padding:0 1rem;box-sizing:border-box}.header-inner,.header-left{display:flex;align-items:center}.header-left{gap:.5rem}.header-left a{display:flex;align-items:center}#logo-img{width:20px;height:auto;vertical-align:middle}.header-nav{display:flex;gap:25px}.header-nav,.nav-link{align-items:center;font-size:15px}.nav-link{position:relative;text-decoration:none;color:inherit;padding-bottom:2px;line-height:1;cursor:pointer;display:inline-flex}#theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:60px;min-width:60px;text-align:center}.nav-link:after{content:"";position:absolute;bottom:-1px;left:0;height:2px;width:100%;background-color:#2081e2;transform:scaleX(0);transform-origin:center;transition:transform .3s ease;pointer-events:none}.nav-link.active-link:after,.nav-link:hover:after{transform:scaleX(1)}.light-mode .nav-link{color:black}.header-text-button{background:none;border:none;padding:0;margin:0;font-size:15px;color:inherit;cursor:pointer;text-decoration:none;transition:opacity .3s ease}.header-text-button:hover{color:#2081e2}html{scroll-behavior:smooth}.mobile-header-wrapper{display:none}.dark-mode{background-color:var(--background-dark);color:var(--text-dark)}.light-mode{background-color:var(--background-light)}.light-mode,.light-mode header,.light-mode main,.light-mode section{color:var(--text-light)}.light-mode .header-button i{color:black}.dark-mode .header-button i{color:white}.light-mode #email{color:black}.light-mode .tag{background-color:#e0e0e0;color:#222}.light-mode #theme-toggle:hover img{background-color:var(--hover-light)}.dark-mode #theme-toggle:hover img{background-color:var(--hover-dark)}.light-mode .experiences-entry:hover{background-color:#d1d1d1a3}.light-mode .experiences-entry{background-color:#a5a5a523}.light-mode .education-entry:hover{background-color:#d1d1d1a3}.light-mode .education-entry{background-color:#a5a5a523}.light-mode .education-entry h3,.light-mode .experience-entry h3{color:#222}.light-mode .about-photo-block p{color:var(--text-light)}.light-mode .skills-heading{color:black}.lighter-text{color:#999}.light-mode .lighter-text{color:#2e2e2e}.light-mode .project-section{color:var(--text-light)}.light-mode .project-title{color:black}.light-mode .project-section p{color:#333}.dark-mode .project-title{color:#f5f5f5}.dark-mode .project-section p{color:#ccc}.light-mode .project-card{background-color:#a5a5a523;color:#222;box-shadow:none}.light-mode .project-card:hover{box-shadow:0 4px 15px rgba(0,0,0,.1)}.light-mode .project-card .project-title{color:#222}.light-mode .project-description{color:#333}:root[data-theme=dark]{--bg:#0f0f0f;--text:#ffffff}:root[data-theme=light]{--bg:#ffffff;--text:#000000}body{background-color:var(--bg);color:var(--text);transition:background-color .2s ease,color .2s ease}@media (max-width:767px){.container{max-width:100vw!important;width:100vw!important;margin:0!important;padding:0 .5rem!important;box-sizing:border-box}.projects-grid{grid-template-columns:1fr;max-width:100vw;margin:0;justify-content:center}.project-card{width:100%;max-width:100%;height:200px;box-sizing:border-box;text-align:left;margin:0 auto}.about-photo-grid{column-count:2;column-gap:1.5rem}.about-photo-block{page-break-inside:avoid;break-inside:avoid;margin-bottom:1rem}.about-photo-block p{font-size:.9rem;text-align:center}.skills-grid-icons{display:grid;grid-template-columns:repeat(3,1fr)!important;grid-gap:1rem;gap:1rem;justify-content:center}.intro-left,.intro-left img{display:none!important}.intro-name{font-size:1rem;font-weight:700;margin-bottom:1rem;white-space:nowrap}.intro-container{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:2rem;padding:2rem 1rem;text-align:center}.intro-right{align-items:left;text-align:left}.education-entry,.experiences-entry{align-items:center;text-align:left;padding:1rem;width:100%;margin:0 auto}.education-icon,.experience-icon{margin:0 auto 1rem;display:block}.desktop-only,.header-inner{display:none!important}.mobile-only{display:inline}.mobile-header{position:fixed;top:0;color:white;left:0;width:100%;padding:.75rem 1rem;background-color:#181c20;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:white!important;border-bottom:2px solid rgb(207,207,207);z-index:1000}.mobile-header-bar{display:flex;align-items:center;justify-content:space-between;max-width:640px;margin:0 auto;padding:0 1rem;width:100%}.hamburger{font-size:30px;background:none;border:none;color:#fff;cursor:pointer;padding:0;margin:1.5rem}.logo-left{display:flex;align-items:center;gap:.4rem;font-size:.9rem;font-weight:500}.logo-left img{width:20px;height:20px}.logo-left span{font-size:.9rem}.mobile-menu-popup{position:fixed;top:0;left:0;height:100vh;background:white;z-index:9999}.mobile-menu-inner,.mobile-menu-popup{width:100%;display:flex;flex-direction:column;gap:2rem}.mobile-menu-inner{padding:1.5rem;height:100%;box-sizing:border-box}.mobile-menu-header{display:flex;justify-content:space-between;align-items:center}header{height:75px}.mobile-nav-links{display:flex;flex-direction:column;gap:1.25rem;font-size:18px}.mobile-nav-link{color:black;text-decoration:none;font-weight:500}.mobile-nav-link:hover{text-decoration:underline}.mobile-subtitle{font-size:.8rem;color:gray;text-align:center;margin-top:4px;letter-spacing:1px}.close-button{font-size:30px;background:none;border:none;color:black;cursor:pointer;padding:0}}