@import"https://rsms.me/inter/inter.css";@import"https://fonts.googleapis.com/css2?family=Railway:wght@400;500;600;700&display=swap";@import"https://fonts.bunny.net/css?family=raleway:100,200,300,400,500,600,700,800,900";:root{--bg: #fafafa;--text: #1f2937;--muted-text: #374151;--soft-text: #6b7280;--line-color: rgba(107, 114, 128, .24);--tile-bg: #ffffff;--tile-border: rgba(156, 163, 175, .5);--divider: #d1d5db;--link: #1f2937;--link-hover: #1f2937;--heading-font: "Railway", "Raleway", "Inter", sans-serif}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;min-height:100%}body{background:var(--bg);color:var(--text);font-family:Raleway,sans-serif;line-height:1.5}body:before{--line-color: rgba(107, 114, 128, .24);--grid-size: 110px;content:"";height:100vh;width:101vw;position:fixed;background:linear-gradient(90deg,var(--line-color) 1px,transparent 1px) 0 0 / var(--grid-size) var(--grid-size),linear-gradient(var(--line-color) 1px,transparent 1px) 0 0 / var(--grid-size) var(--grid-size);top:0;z-index:-1;-webkit-mask:linear-gradient(-360deg,transparent 30%,white);mask:linear-gradient(-360deg,transparent 30%,white)}@media(prefers-color-scheme:dark){body:before{--line-color: rgba(56, 56, 56, .84)}}.home-tile{@apply p-4 md:p-6 rounded-lg hover:border-sky-500 transition bg-white dark:bg-neutral-900 border border-gray-400/50;}h2{@apply text-lg font-semibold;}:root,.font-inter{font-family:Inter,sans-serif;font-feature-settings:"liga" 1,"calt" 1}.font-sans{font-family:Raleway,sans-serif}@supports (font-variation-settings: normal){:root{font-family:InterVariable,sans-serif}}.site-shell{margin-inline:auto;min-height:100vh;width:100%;display:flex;flex-direction:column;align-items:center;padding-inline:.5rem}.home-shell{width:100%;min-height:calc(100vh - 3rem);display:flex;justify-content:center;align-items:center;padding-block:2rem}.home-grid{color:var(--text);margin:auto;width:100%;max-width:72rem;position:relative;overflow:hidden;display:grid;gap:.5rem;padding:.5rem}.tile{background:var(--tile-bg);border:1px solid var(--tile-border);border-radius:.5rem;padding:.75rem;transition:border-color .2s ease,transform .2s ease}.tile:hover{border-color:#0ea5e9}.tile h2{margin:0 0 .5rem;font-size:1.125rem;font-weight:600;font-family:var(--heading-font)}.tile-hero{display:flex;gap:.5rem;align-items:center;font-weight:300;overflow:hidden}.tile-hero p{margin:0}.hero-name{font-weight:600;font-size:1.5rem;font-family:var(--heading-font)}.hero-photo{width:auto;max-height:120px;border-radius:.5rem;user-select:none}.about-copy{margin:0;font-size:.875rem;color:var(--muted-text);line-height:1.4}.about-copy strong{font-weight:600;color:var(--text)}.about-proof{font-size:.75rem;text-decoration:underline}.about-proof:hover{color:#0284c7}.project-listing{display:flex;flex-direction:column;gap:.25rem}.projects-preview h2{margin-bottom:0}.project-listing a{color:var(--link);display:block;padding:.5rem;text-decoration:none;transition:background-color .15s ease}.project-listing a+a{border-top:1px solid var(--divider)}.project-listing a:hover{background-color:#f3f4f6cc}.project-listing a:visited{color:var(--link)}.project-listing a:active{background-color:#e5e7ebcc}.project-listing-title{margin-bottom:.25rem}.project-listing-tags{margin-left:-.25rem;font-size:.75rem;color:var(--soft-text);display:flex;flex-wrap:wrap}.project-listing-tags span{padding-inline:.25rem}.project-listing-tags span+span{border-left:1px solid var(--divider)}.view-all-link{margin-top:.75rem;font-size:.875rem;text-decoration:none;display:inline-block}.projects-preview .view-all-link{margin-top:auto}.view-all-link:hover{text-decoration:underline}.link-primary,.breadcrumbs a,.about-copy a,.contact-row a,.view-all-link{color:var(--link);text-decoration:none}.link-primary:visited,.breadcrumbs a:visited,.about-copy a:visited,.contact-row a:visited,.view-all-link:visited{color:var(--link)}.about-proof:hover,.contact-row a:hover{text-decoration:underline}.skills-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;min-height:75%}.skills{padding-block:1rem}.skill-item{display:flex;flex-direction:column;align-items:center}.skill-item img{max-width:2.5rem;max-height:2.5rem}.skill-item span{opacity:0;height:0;overflow:hidden;font-size:.75rem;transition:opacity .2s ease,height .2s ease}.skill-item:hover span{opacity:1;height:1.25rem}.contact-row{margin-top:.5rem;display:flex;flex-direction:row;align-items:center;gap:.5rem;width:100%}.contact-row svg,.contact-row img{max-width:1rem;max-height:1rem}.contact-row a{text-decoration:none;font-size:.95rem}.contact-row a:hover{text-decoration:underline;color:#0284c7}.content-page{width:100%;max-width:48rem;margin-block:.5rem 2rem}.breadcrumbs{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.95rem}.breadcrumbs a{color:var(--link);text-decoration:none}.breadcrumbs a:hover{text-decoration:underline}.card{background:var(--tile-bg);border:1px solid rgba(107,114,128,.2);border-radius:.5rem;padding:1rem}.card h1{margin-top:0;margin-bottom:1rem;font-size:2rem;font-family:var(--heading-font)}.project-image{width:100%;max-height:16rem;object-fit:contain}.project-header{margin:1.5rem 0;text-align:center}.project-subtitle{color:var(--soft-text);font-size:.875rem}.project-body{margin-top:2rem;font-size:.95rem;line-height:1.9}.project-body h2,.project-body h3{margin-top:2rem;line-height:1.3;font-family:Inter,sans-serif}.project-body ul,.project-body ol{padding-left:1.3rem}.project-video{width:100%;height:24rem;margin-top:1rem}.project-video iframe,.project-video video{width:100%;height:100%;object-fit:contain}.logo-dark-only{display:none}@media(min-width:640px){.home-grid{padding:1rem}}@media(min-width:768px){.home-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;padding:1.25rem}.tile{padding:1rem}.hover-rotate-left:hover{transform:rotate(-1deg)}.hover-rotate-right:hover{transform:rotate(1deg)}.hero{grid-column:1 / -1}.about{grid-column:2;grid-row:span 3}.projects-preview{grid-column:1;grid-row:span 2;display:flex;flex-direction:column;gap:.75rem;height:100%;min-height:0}.projects-preview .project-listing{flex:1}.skills{grid-column:1;padding-block:1rem}.contact{grid-column:1}.hero-photo{max-height:220px}}@media(min-width:1024px){.home-grid{grid-template-columns:repeat(6,minmax(0,1fr));grid-template-rows:repeat(4,minmax(0,1fr));gap:1rem;max-height:800px}.tile{padding:1.25rem}.hero{grid-column:span 4;grid-row:span 2}.about{grid-column:span 2;grid-row:span 4}.projects-preview{grid-column:span 2;grid-row:span 2}.skills,.contact{grid-column:span 2;grid-row:span 1}.hero-photo{max-height:300px}.content-page{max-width:56rem;margin-block:2rem}.card{padding:1.5rem}}@media(prefers-color-scheme:dark){:root{--bg: #000000;--text: #f9fafb;--muted-text: #f3f4f6;--soft-text: #9ca3af;--line-color: rgba(56, 56, 56, .84);--tile-bg: #171717;--tile-border: rgba(75, 85, 99, .8);--divider: #4b5563;--link: #e5e7eb;--link-hover: #e5e7eb}.project-listing a:hover{background-color:#1f2937cc}.project-listing a:active{background-color:#374151cc}.logo-dark-only{display:flex}.logo-light-only{display:none}.invert-dark{filter:invert(1)}}@media(prefers-color-scheme:light){.logo-dark-only{display:none}}iframe{border:none;width:100%}
