:root{--font-body: "DM Sans", system-ui, Avenir, Helvetica, Arial, sans-serif;--font-header: "Instrument Serif", serif;--font-accent: "Estedad-VF", sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;background:#eee;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#000}html,body{margin:0;padding:0;width:100%;height:100%;font-family:var(--font-body);cursor:crosshair;scroll-behavior:smooth}h1,h2,h3,h4,h5,h6{font-family:var(--font-header);line-height:1.1}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}#root{max-width:100%;margin:0 auto;padding:0;height:100%;text-align:center}app.content{flex:1}.app-container{display:flex;flex-direction:column;min-height:100vh}.navbar{display:flex;justify-content:space-between;align-items:center;width:100vw;padding:2.3rem 8.3rem;border-bottom:.1px solid rgb(213,210,210);top:0;box-sizing:border-box;font-style:initial}.navbar-left a{font-weight:600;font-size:.74rem;color:gray;text-decoration:none}.navbar-actions{display:flex;align-items:center;gap:1rem}.navbar-right{display:flex;align-items:center;gap:3.2rem}.navbar .burger{display:none}.navbar-right a{text-decoration:none;color:gray;font-weight:435;font-size:.77rem;transition:color .2s}.navbar-right a:hover{color:#747bff}@media (max-width: 900px){.navbar{padding:1rem 1.25rem}.navbar-right{display:none}.navbar .burger{display:flex;position:fixed;top:1rem;right:1rem;z-index:100}.navbar.open .navbar-right{display:flex;position:fixed;top:64px;right:1rem;flex-direction:column;align-items:flex-end;gap:1rem;background:#fffffff2;padding:1rem 1.25rem;border:1px solid #eaeaea;border-radius:8px;box-shadow:0 10px 24px #0000001f}}.burger{width:25px;height:25px;display:flex;flex-direction:column;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;cursor:pointer;transition:.3s;background:transparent;border:none;padding:0;appearance:none;-webkit-appearance:none}.burger input[type=checkbox]{appearance:none;transition:.3s;background:transparent;position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer}.burger:before,.burger:after{content:"";transition:.3s;transform-origin:center center;background:#000}.burger:before{transform:translateY(8px)}.burger:after{transform:translateY(-8px)}.burger .line,.burger:before,.burger:after{width:20px;height:2.1px;display:block;border-radius:5px;position:absolute}.burger .line:checked{width:0;transition-delay:50ms}.burger:has(.line:checked):before{animation:animation1 .4s ease-out 0s 1 both}.burger:has(.line:checked):after{animation:animation2 .4s ease-out 0s 1 both}.burger:hover{border-radius:50%}.burger:hover .line,.burger:hover:before,.burger:hover:after{background:#000}.burger:active{scale:.95}@keyframes animation1{0%{transform:translateY(8px) rotate(0)}50%{transform:translateY(0) rotate(0)}to{transform:translateY(0) rotate(45deg)}}@keyframes animation2{0%{transform:translateY(-8px) rotate(0)}50%{transform:translateY(0) rotate(0)}to{transform:translateY(0) rotate(-45deg)}}.footer{display:flex;flex-direction:row;justify-content:space-between;align-items:center;width:100%;padding:2.3rem 8.3rem;position:relative;left:0;bottom:0;border-top:.1px solid rgb(213,210,210);box-sizing:border-box;font-style:initial}.footer-left p{font-weight:600;font-size:.74rem;color:gray;text-decoration:none}.footer-right{display:flex;align-items:center;gap:3.2rem}.footer-right a{text-decoration:none;color:gray;font-weight:435;font-size:.77rem;transition:color .2s}.footer-right a:hover{color:#bcbed9}@media (max-width: 900px){.footer{flex-direction:column;display:flex;gap:1rem;width:100vw;left:0;right:0;padding:1.5rem 1rem;justify-content:center;align-items:center;text-align:center}.footer-left,.footer-right{width:100%;justify-content:center}.footer-right{gap:1.5rem}}.home-container{max-width:1000px;margin:0 auto;padding:3rem 1.5rem;min-height:100vh;display:flex;flex-direction:column;gap:3.5rem}.hero-section{display:flex;flex-direction:column;align-items:flex-start;gap:1rem;max-width:800px}.hero-title{font-size:2.75rem;line-height:1.15;font-weight:200;color:#1a1a1a;letter-spacing:-.02em;margin:0}.scrolling-text-gradient{background:linear-gradient(90deg,#2563eb,#7c3aed,#db2777,#2563eb);background-size:200% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:500;animation:shine 5s linear infinite;display:inline-block}@keyframes shine{to{background-position:200% center}}.hero-subtitle{font-size:1rem;color:#6b7280;font-weight:300;margin:0}.break-on-desktop{display:block}.cta-group{display:flex;gap:.75rem;margin-top:.5rem}.cta-button{display:inline-flex;align-items:center;justify-content:center;padding:.6rem 1.25rem;border-radius:9999px;font-weight:500;font-size:.9rem;text-decoration:none;transition:all .2s ease}.cta-button.primary{background-color:#1a1a1a;color:#fff;border:1px solid #1a1a1a}.cta-button.primary:hover{background-color:#333;transform:translateY(-1px)}.cta-button.secondary{background-color:transparent;color:#1a1a1a;border:1px solid #e5e5e5}.cta-button.secondary:hover{border-color:#1a1a1a}.featured-work{width:100%}.section-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1.25rem;border-bottom:1px solid #f3f4f6;padding-bottom:.75rem}.section-title{font-size:1.25rem;font-weight:400;color:#1a1a1a;margin:0}.view-all-link{font-size:.85rem;color:#6b7280;text-decoration:none;transition:color .2s}.view-all-link:hover{color:#1a1a1a}.feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.feature-card{display:block;text-decoration:none;cursor:pointer}.card-image-wrapper{border-radius:10px;overflow:hidden;margin-bottom:.75rem;box-shadow:0 4px 6px -1px #0000000d;transition:all .3s ease;aspect-ratio:16/9}.feature-card:hover .card-image-wrapper{transform:translateY(-3px);box-shadow:0 15px 20px -5px #0000001a}.card-image-wrapper img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.feature-card:hover .card-image-wrapper img{transform:scale(1.03)}.card-info{display:flex;flex-direction:column;gap:.15rem}.card-category{font-size:.7rem;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em}.card-title{font-size:1.1rem;font-weight:500;color:#1a1a1a;margin:0}.quick-links{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.link-card{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;background-color:#f9fafb;border-radius:10px;text-decoration:none;color:#1a1a1a;border:1px solid transparent;transition:all .2s ease}.link-card:hover{background-color:#fff;border-color:#e5e5e5;box-shadow:0 4px 6px -1px #0000000d}.link-label{font-weight:500;font-size:1rem}.link-arrow{color:#9ca3af;transition:transform .2s ease}.link-card:hover .link-arrow{transform:translate(4px);color:#1a1a1a}@media (max-width: 768px){.home-container{padding:3rem 1.5rem;gap:4rem}.hero-title{font-size:2.5rem}.break-on-desktop{display:inline}.feature-grid{grid-template-columns:1fr;gap:2.5rem}.quick-links{grid-template-columns:1fr}}.about-section{padding:3rem 10rem;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:4rem}.about-text h1{font-size:2.4rem;line-height:1.2;margin-bottom:1rem;font-weight:100;color:#3f3e3e}.about-container{display:grid;grid-template-columns:8fr 3fr;gap:3rem;width:100%}.about-text{display:flex;flex-direction:column;justify-content:center;text-align:left}.about-text p{font-size:1rem;font-weight:300;color:gray;line-height:1.6}.highlight{font-weight:500;color:#000}.about-image{margin-top:3rem;display:flex;align-items:center;justify-content:flex-end;width:390px;height:375px;border-radius:8px;box-shadow:1px 5px 4px 5px #0000001a}.gallery-section{display:flex;flex-direction:column;align-items:center;width:100%}.gallery-title{font-weight:100;font-size:2.4rem;color:#3f3e3e;text-align:left}.image-row{display:grid;grid-template-columns:repeat(4,1fr);gap:6rem}.image-row img{width:225px;height:225px;object-fit:cover}@media (max-width: 900px){.about-section{padding:2rem;gap:3rem}.about-container{grid-template-columns:1fr;gap:2rem}.about-image{width:100%;height:auto;justify-content:center}.gallery-title{font-size:2rem;text-align:left;width:100%}.image-row{grid-template-columns:repeat(2,1fr);gap:1.25rem;width:100%}.image-row img{width:100%;height:160px;border-radius:8px}}@media (max-width: 1024px){.about-section{padding:2rem 4rem;gap:3rem}.about-container{grid-template-columns:1fr;gap:2rem}.about-image{width:100%;height:auto;justify-content:center}.gallery-title{font-size:2rem;text-align:center}.image-row{grid-template-columns:repeat(2,1fr);gap:2rem;width:100%;justify-items:center}.image-row img{width:80%;width:300px;height:300px;border-radius:8px}}@media (max-width: 600px){.about-section{padding:1.25rem;gap:2rem}.about-text h1{font-size:1.8rem;text-align:center}.about-text p{font-size:.95rem;text-align:center}.about-image{width:100%;height:auto;justify-content:center;margin-top:1rem}.gallery-title{font-size:1.75rem;text-align:center}.image-row{grid-template-columns:1fr;gap:1rem;width:100%}.image-row img{width:300px;height:200px}}@media (max-width: 375px){.about-section{padding:1rem;gap:1.5rem}.about-text h1{font-size:1.5rem}.about-text p{font-size:.9rem}.gallery-title{font-size:1.5rem}.image-row img{height:180px}}.icon-button-wrapper{display:flex;justify-content:center;align-items:center}.icon-button{display:inline-flex;align-items:center;justify-content:center;padding:.5rem;border-radius:.375rem;color:#000;font-weight:600;transition:transform .2s ease,color .2s ease;cursor:pointer;background:transparent}.icon-button:hover{transform:scale(1.25)}.icon-button:hover svg{stroke:#3b82f6}.linkedin-bg{background-color:#0077b5}.github-icon{width:2rem;height:2rem}.linkedin-icon{width:1.25rem;height:1.25rem}.email-icon{width:2.5rem;height:2.5rem}.projects-section{position:relative;min-height:100vh;padding:3rem 2rem;overflow:hidden}.projects-content-wrapper{position:relative;z-index:1;max-width:1200px;margin:0 auto}.projects-title{font-size:2.4rem;font-weight:100;color:#3f3e3e;margin-bottom:2.5rem;text-align:left}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:2rem}.project-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;transition:transform .3s ease,box-shadow .3s ease;display:flex;flex-direction:column;height:100%}.project-card:hover{transform:translateY(-5px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.project-media{position:relative;height:200px;overflow:hidden;background-color:#f1f5f9}.project-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.project-card:hover .project-media img{transform:scale(1.05)}.media-overlay{position:absolute;inset:0;background:#0000004d;opacity:0;display:flex;align-items:center;justify-content:center;transition:opacity .3s ease}.project-card:hover .media-overlay{opacity:1}.overlay-link{color:#fff;border:1px solid white;padding:.5rem 1rem;border-radius:20px;text-decoration:none;font-weight:500;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background .2s}.overlay-link:hover{background:#fff3}.project-info{padding:1.5rem;display:flex;flex-direction:column;flex-grow:1}.project-title{font-size:1.25rem;font-weight:600;color:#1a202c;margin-bottom:.5rem}.project-description{font-size:.95rem;color:#64748b;line-height:1.5;margin-bottom:1rem;flex-grow:1}.project-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem}.project-tags span{font-size:.75rem;color:#475569;background-color:#f1f5f9;padding:.25rem .6rem;border-radius:4px;font-family:monospace}.project-links{display:flex;gap:1rem;font-size:.9rem}.project-links a{text-decoration:none;color:#3b82f6;font-weight:500;transition:color .1s}.project-links a:hover{color:#2563eb;text-decoration:underline}.project-gradient{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem;color:#ffffffe6}.gradient-rise{background:linear-gradient(135deg,#1e3a8a,#3b82f6,#60a5fa)}.gradient-crowd{background:linear-gradient(135deg,#0f766e,#14b8a6,#2dd4bf)}.gradient-stock{background:linear-gradient(135deg,#111827,#374151,#6b7280)}@media (max-width: 768px){.projects-section{padding:2rem 1rem}.projects-grid{grid-template-columns:1fr}.project-media{height:180px}}.experience-section{padding:3rem 2rem;width:100%;box-sizing:border-box;display:flex;justify-content:center;overflow-x:hidden}.experience-max-width{max-width:1000px;width:100%}.experience-title{font-size:2.4rem;font-weight:100;color:#3f3e3e;margin-bottom:3rem;text-align:left}.timeline{position:relative;display:flex;flex-direction:column;gap:2rem;box-sizing:border-box;width:100%}.timeline *{box-sizing:border-box}.timeline:after{content:"";position:absolute;width:2px;background-color:#e5e5e5;top:0;bottom:0;left:50%;transform:translate(-50%);z-index:0}.timeline-item{position:relative;width:50%;padding:0 2rem;z-index:1}.timeline-item.left{left:0;text-align:right}.timeline-item.right{left:50%;text-align:left}.timeline-item:after{content:"";position:absolute;width:12px;height:12px;border-radius:50%;background-color:#fff;border:2px solid #3f3e3e;top:1.5rem;z-index:2}.timeline-item.left:after{right:0;transform:translate(50%)}.timeline-item.right:after{left:0;transform:translate(-50%)}.timeline-content{background-color:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 4px 12px #0000000d;border:1px solid #f0f0f0;transition:transform .2s ease,box-shadow .2s ease;width:100%}.timeline-content:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001a}.role-badge{display:inline-block;font-size:.8rem;font-weight:500;color:#8b5cf6;background-color:#f3f0ff;padding:.25rem .5rem;border-radius:4px;margin-bottom:.5rem}.organization-name{font-size:1.25rem;font-weight:600;color:#1a1a1a;margin:.25rem 0;word-wrap:break-word}.org-link{text-decoration:none;color:inherit;transition:color .1s ease}.org-link:hover{color:#3b82f6}.link-arrow{font-size:.8em;color:#9ca3af}.meta-info{display:flex;flex-direction:column;gap:0;margin-bottom:1rem;font-size:.9rem;color:#6b7280}.timeline-item.left .meta-info{align-items:flex-end}.timeline-item.right .meta-info{align-items:flex-start}.details-list{list-style:none;padding:0;margin:0;text-align:left}.details-list li{position:relative;padding-left:1rem;margin-bottom:.5rem;font-size:.95rem;color:#4b5563;line-height:1.5}.details-list li:before{content:"•";position:absolute;left:0;color:#9ca3af}@media (max-width: 768px){.experience-section{padding:3rem 1rem}.timeline:after{left:20px;transform:none}.timeline-item{width:100%;padding-left:50px;padding-right:0;text-align:left}.timeline-item.left,.timeline-item.right{left:0}.timeline-item.left:after,.timeline-item.right:after{left:14px;right:auto;transform:none}.timeline-item.left .meta-info{align-items:flex-start}}.pillpall-section{padding:3rem 10rem;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:2.5rem}.pillpall-header{display:flex;flex-direction:column;align-items:flex-start;width:100%}.pillpall-title{font-size:2.4rem;line-height:1.2;margin-bottom:.5rem;font-weight:100;color:#3f3e3e;align-self:flex-start}.pillpall-subtitle{font-size:1rem;font-weight:300;color:gray;line-height:1.6}.pillpall-description{width:900px;margin:0 auto;text-align:left}.pillpall-description p{font-size:1rem;font-weight:300;color:gray;line-height:1.6}.pillpall-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;width:100%;border-radius:8px}.pillpall-gallery img{width:100%;border-radius:8px;object-fit:cover;background:#f3f3f3;cursor:zoom-in}@media (max-width: 1024px){.pillpall-gallery{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.pillpall-section{padding:2rem}.pillpall-gallery{grid-template-columns:1fr}}.pillpall-lightbox{position:fixed;inset:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:50}.pillpall-lightbox-inner{max-width:90vw;max-height:90vh}.pillpall-lightbox-inner img{width:100%;height:auto;border-radius:10px;box-shadow:0 20px 40px #00000059}.ucla-section{padding:3rem 10rem;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:2.5rem}.ucla-header{display:flex;flex-direction:column;align-items:flex-start;width:100%}.ucla-title{font-size:2.4rem;line-height:1.2;margin-bottom:.5rem;font-weight:100;color:#3f3e3e}.ucla-subtitle{font-size:1rem;font-weight:300;color:gray;line-height:1.6}.ucla-description{width:100%}.ucla-description p{font-size:1rem;font-weight:300;color:gray;line-height:1.6}.ucla-video{width:100%}.ucla-video-inner{position:relative;width:100%;padding-bottom:56.25%;border-radius:8px;overflow:hidden;background:#000}.ucla-video-inner iframe{position:absolute;inset:0;width:100%;height:100%;border:0}.ucla-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;width:100%}.ucla-gallery img{width:100%;border-radius:8px;object-fit:cover;background:#f3f3f3}@media (max-width: 1024px){.ucla-gallery{grid-template-columns:1fr}}@media (max-width: 640px){.ucla-section{padding:2rem}}.ucla-details{max-width:900px;margin:0 auto;text-align:left}.btd-section{padding:3rem 10rem;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:2.5rem}.btd-header{display:flex;flex-direction:column;align-items:flex-start;width:100%}.btd-title{font-size:2.4rem;line-height:1.2;margin-bottom:.5rem;font-weight:100;color:#3f3e3e;align-self:flex-start}.btd-subtitle{font-size:1rem;font-weight:300;color:gray;line-height:1.6}.btd-description{width:900px;margin:0 auto;text-align:left}.btd-description p{font-size:1rem;font-weight:300;color:gray;line-height:1.6}.btd-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;width:100%;border-radius:8px}.btd-gallery img{width:100%;border-radius:8px;object-fit:cover;background:#f3f3f3;cursor:zoom-in}@media (max-width: 1024px){.btd-gallery{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.btd-section{padding:2rem}.btd-gallery{grid-template-columns:1fr}}.btd-lightbox{position:fixed;inset:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:50}.btd-lightbox-inner{max-width:90vw;max-height:90vh}.btd-lightbox-inner img{width:100%;height:auto;border-radius:10px;box-shadow:0 20px 40px #00000059}.bruinwalk-section{padding:3rem 10rem;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:2.5rem}.bruinwalk-header{display:flex;flex-direction:column;align-items:flex-start;width:100%}.bruinwalk-title{font-size:2.4rem;line-height:1.2;margin-bottom:.5rem;font-weight:100;color:#3f3e3e;align-self:flex-start}.bruinwalk-subtitle{font-size:1rem;font-weight:300;color:gray;line-height:1.6}.bruinwalk-description{width:900px;margin:0 auto;text-align:left}.bruinwalk-description p{font-size:1rem;font-weight:300;color:gray;line-height:1.6}.bruinwalk-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;width:100%;border-radius:8px}.bruinwalk-gallery img{width:100%;border-radius:8px;object-fit:cover;background:#f3f3f3;cursor:zoom-in}@media (max-width: 1024px){.bruinwalk-gallery{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.bruinwalk-section{padding:2rem}.bruinwalk-gallery{grid-template-columns:1fr}}.bruinwalk-lightbox{position:fixed;inset:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:50}.bruinwalk-lightbox-inner{max-width:90vw;max-height:90vh}.bruinwalk-lightbox-inner img{width:100%;height:auto;border-radius:10px;box-shadow:0 20px 40px #00000059}.uclaclubhouse-section{padding:3rem 10rem;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:2.5rem}.uclaclubhouse-header{display:flex;flex-direction:column;align-items:flex-start;width:100%}.uclaclubhouse-title{font-size:2.4rem;line-height:1.2;margin-bottom:.5rem;font-weight:100;color:#3f3e3e;align-self:flex-start}.uclaclubhouse-subtitle{font-size:1rem;font-weight:300;color:gray;line-height:1.6}.uclaclubhouse-description{width:900px;margin:0 auto;text-align:left}.uclaclubhouse-description p{font-size:1rem;font-weight:300;color:gray;line-height:1.6}.uclaclubhouse-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;width:100%;border-radius:8px}.uclaclubhouse-gallery img{width:100%;border-radius:8px;object-fit:cover;background:#f3f3f3;cursor:zoom-in}@media (max-width: 1024px){.uclaclubhouse-gallery{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.uclaclubhouse-section{padding:2rem}.uclaclubhouse-gallery{grid-template-columns:1fr}}.uclaclubhouse-lightbox{position:fixed;inset:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:50}.uclaclubhouse-lightbox-inner{max-width:90vw;max-height:90vh}.uclaclubhouse-lightbox-inner img{width:100%;height:auto;border-radius:10px;box-shadow:0 20px 40px #00000059}
