*, *::before, *::after { box-sizing: border-box; }
*:not(dialog) { margin: 0; }
@media (prefers-reduced-motion: no-preference) {
  html { interpolate-size: allow-keywords; }
}
body { line-height: 1.5; -webkit-font-smoothing: antialiased; }
img, picture, video, canvas, svg { display: block; max-width: 100%; }
input, button, textarea, select { font: inherit; }
p, h1, h2, h3, h4, h5, h6 { overflow-wrap: break-word; }
p { text-wrap: pretty; }
h1, h2, h3, h4, h5, h6 { text-wrap: balance; }
html { font-family: 'Montserrat', sans-serif; color: #fff; background-color: #111; min-height: 100vh; scroll-behavior: smooth; scroll-padding-top: 5rem; }
button, .button { display: flex; justify-content: center; align-items: center; gap: 0.5rem; height: 2.5rem; border-radius: 1.25rem; font-size: 1rem; padding: 0.5rem 2rem; font-weight: 700; text-decoration: none; color: #fff; text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.4); background-color: rgb(231, 66, 174); }
button:hover, .button:hover { background-color: rgba(231, 66, 174, 0.8); }
button:disabled, .button:disabled { background-color: rgba(231, 66, 174, 0.5); }
.pill { display: flex; justify-content: center; align-items: center; gap: 0.5rem; border-radius: 1.25rem; font-size: 1rem; padding: 0.5rem 2rem; font-weight: 700; text-decoration: none; color: #fff; text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.4);border: 1px solid rgb(105, 227, 241); background-color: rgba(105, 227, 241, 0.3); }
.actions { display: flex; flex-direction: row; gap: 1rem; padding: 1rem 0; flex-wrap: wrap; }
header { position: sticky; top: 0; padding: 1rem 2rem; display: flex; justify-content: space-between; align-items: center; font-size: 1.2rem; backdrop-filter: blur(10px); }
header h1 { display: flex; align-items: center; gap: 1rem; font-size: 1.5rem; }
header h1 img { width: 3rem; height: 3rem; border-radius: 50%; }
header nav ul { list-style: none; display: flex; flex-direction: row; gap: 1rem; padding: 0; margin: 0; font-size: clamp(12px, 3vw, 16px); }
header nav ul li a { text-decoration: none; color: inherit; padding: 0.5rem 0.75rem; border-radius: 0.5rem; }
header nav ul li a:hover { background-color: rgba(255, 255, 255, 0.1); }
#about { display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 1rem; padding: 5rem 2rem; text-align: center; background: linear-gradient(45deg in lch, rgba(231, 66, 174, 0.3), rgba(105, 227, 241, 0.3)) }
#about h2 { font-size: 2rem; font-weight: 800; }
#about p { max-width: 600px; font-weight: 500; }
#founders { display: flex; flex-direction: row; justify-content: space-between; align-items: flex-start; gap: 1rem; padding: 3rem 2rem; }
#founders h2 { font-size: 1.75rem; font-weight: 800; }
#founders .founder { display: flex; flex-direction: column; justify-content: flex-start; align-items: flex-start; gap: 1rem; padding: 0 2rem 2rem 2rem; text-align: left; }
#founders .founder h3 { display: flex; flex-direction: row; justify-content: center; align-items: center; gap: 1rem; font-size: 1.5rem; font-weight: 700; }
#founders .founder-handle { font-size: 1.25rem; font-weight: 600; color: rgb(105, 227, 241); }
#founders .founder-social-links { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: row; justify-content: flex-start; align-items: flex-start; gap: 1rem; }
.social-button { flex-shrink: 0; height: 36px; color: white; text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.4); text-decoration: none; border-radius: 18px; font-size: 0.875rem; font-weight: 600; padding: 0.5rem 1rem; display: flex; align-items: center; justify-content: center; gap: 0.25rem; transition: all 0.3s ease; }
.social-button svg { width: 23px; height: 23px; object-fit: contain; fill: white; filter: drop-shadow(1px 1px 2px rgba(0, 0, 0, 0.4)); }
.social-button--x { background-color: black; border: 1px solid white; }
.social-button--farcaster { background-color: rgb(106, 60, 255); }
.social-button--farcaster:hover { background-color: rgba(106, 60, 255, .8); }
.social-button--x:hover { border-color: rgba(255, 255, 255, .8); }
#portfolio { display: flex; flex-direction: row; justify-content: flex-start; align-items: flex-start; gap: 1rem; padding: 3rem 2rem; }
#portfolio h2 { font-size: 1.75rem; font-weight: 800; }
#portfolio .project { display: flex; flex-direction: column; justify-content: flex-start; align-items: flex-start; gap: 1rem; padding: 0 2rem 2rem 2rem; text-align: left; }
#portfolio .project h3 { font-size: 1.5rem; font-weight: 700; }
#portfolio .project .project-stats { display: flex; flex-direction: row; justify-content: flex-start; align-items: flex-start; gap: 1rem; flex-wrap: wrap; }
#portfolio .project .project-stats article { display: flex; flex-direction: column-reverse; justify-content: flex-start; align-items: flex-start; font-size: 1.5rem; font-weight: 500; padding: 0.5rem 1rem; border: 1px solid rgba(255, 255, 255, 0.5); border-radius: 0.5rem; background-color: rgba(255, 255, 255, 0.1); }
#portfolio .project .project-stats article h4 { font-size: 1rem; font-weight: 700; }
footer { display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 1rem; padding: 2rem 2rem; text-align: center; }

@media screen and (max-width: 768px) {
  header { flex-direction: column; justify-content: center; align-items: center; gap: 1rem; }
  header nav ul { flex-wrap: wrap; justify-content: center; align-items: center; gap: 0.5rem; }
}

@media screen and (max-width: 1024px) {
  #founders { flex-direction: column; justify-content: flex-start; align-items: flex-start; gap: 1.5rem; }
  #founders .founder { margin: 0; padding: 0; }
  #portfolio { flex-direction: column; justify-content: flex-start; align-items: flex-start; gap: 1.5rem; }
  #portfolio .project { margin: 0; padding: 0; }
}