body { font-family: "Noto Sans", sans-serif; }

.section { padding: 2rem 1.5rem; }

.hero + .hr + .section { padding-top: 1rem; }

.title { font-family: 'Google Sans'; font-weight: 700; }

.portrait { border-radius: 8px; overflow: hidden; }
.portrait img { width: 100%; display: block; transform: scale(1); }

.footer .footer-links a { font-size: 25px; color: #000; }

.publication-block .publication-title { width: fit-content; margin: 0 !important; font-weight: 600; font-size: 110% !important; }
.publication-block .publication-title a { color: #000; }
.publication-block .publication-venue { color: #555; width: fit-content; margin-top: 0; }
.publication-block .publication-venue-emph { font-style: normal; font-size: 80%; font-weight: 500; color: firebrick; padding-left: 0.25em; }
.publication-block .publication-awards { color: firebrick; width: fit-content; font-weight: bolder; }
.publication-block .publication-authors .author-me { color: #000; font-weight: 600; }
.publication-block .publication-authors a { color: #000 !important; }
.publication-block .publication-authors a:hover { text-decoration: underline; }
.publication-block .publication-image { border-radius: 4px; width: 100%; height: auto; max-width: 120px; /* Reduced size */ margin: 0 auto; overflow: hidden; font-size: 0; }
.publication-block .publication-image img { width: 100%; height: auto; display: block; }
.publication-block .publication-mousecell { position: relative; font-size: 0; }
.publication-block .publication-mousecell { width: 100%; height: 100%; display: inline-block; overflow: hidden; }
.publication-block .publication-mousecell video { display: none; }
.publication-block .publication-description { color: #333; margin: 0.5em 0; }
.publication-block .publication-links { margin: 0 !important; margin-top: 0.5em !important; }
.publication-block.selected { background-color: rgba(0, 0, 0, 0.05); border-radius: 0 8px 8px 0; padding-top: 1rem; padding-bottom: 1rem; margin-bottom: 1.5rem; border-left: 4px solid firebrick; }
.publication-block.selected .column:first-child { padding-left: 1.5rem; }

.project-block .project-title { width: fit-content; margin: 0 !important; font-weight: 600; font-size: 110% !important; }
.project-block .project-title a { color: #000; }
.project-block .project-venue { color: #555; width: fit-content; margin-top: 0; }
.project-block .project-venue-emph { font-style: normal; font-size: 80%; font-weight: 500; color: firebrick; padding-left: 0.25em; }
.project-block .project-awards { color: firebrick; width: fit-content; font-weight: bolder; }
.project-block .project-authors .author-me { color: #000; font-weight: 600; }
.project-block .project-authors a { color: #000 !important; }
.project-block .project-authors a:hover { text-decoration: underline; }
.project-block .project-image { border-radius: 4px; width: 100%; height: auto; max-width: 120px; /* Reduced size */ margin: 0 auto; overflow: hidden; font-size: 0; }
.project-block .project-image img { width: 100%; height: auto; display: block; }
.project-block .project-mousecell { position: relative; font-size: 0; }
.project-block .project-mousecell { width: 100%; height: 100%; display: inline-block; overflow: hidden; }
.project-block .project-mousecell video { display: none; }
.project-block .project-description { color: #333; margin: 0.5em 0; }
.project-block .project-links { margin: 0 !important; margin-top: 0.5em !important; }

.software-block .software-title { width: fit-content; margin: 0 !important; font-weight: 600; font-size: 110% !important; }
.software-block .software-title a { color: #000; }
.software-block .software-venue { color: #555; width: fit-content; margin-top: 0; }
.software-block .software-venue-emph { font-style: normal; font-size: 80%; font-weight: 500; color: firebrick; padding-left: 0.25em; }
.software-block .software-awards { color: firebrick; width: fit-content; font-weight: bolder; }
.software-block .software-authors .author-me { color: #000; font-weight: 600; }
.software-block .software-authors a { color: #000 !important; }
.software-block .software-authors a:hover { text-decoration: underline; }
.software-block .software-image { border-radius: 4px; width: 100%; height: auto; max-width: 120px; /* Reduced size */ margin: 0 auto; overflow: hidden; font-size: 0; }
.software-block .software-image img { width: 100%; height: auto; display: block; }
.software-block .software-mousecell { position: relative; font-size: 0; }
.software-block .software-mousecell { width: 100%; height: 100%; display: inline-block; overflow: hidden; }
.software-block .software-mousecell video { display: none; }
.software-block .software-description { color: #333; margin: 0.5em 0; }
.software-block .software-links { margin: 0 !important; margin-top: 0.5em !important; }

.gallery-section { padding-bottom: 3rem; }
.gallery-section .gallery-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.5rem; margin-top: 2rem; }
.gallery-section .gallery-item { border-radius: 8px; overflow: hidden; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1); transition: transform 0.3s ease; }
.gallery-section .gallery-item:hover { transform: scale(1.02); }
.gallery-section .gallery-item img { width: 100%; height: 250px; object-fit: cover; display: block; }
