/* === Components === */

/* Project rows */
.project-list {
  display: flex;
  flex-direction: column;
}

.project {
  padding: var(--space-md) 0;
  border-bottom: 1px solid var(--border);
  transition: background-color var(--transition);
}

.project:first-child {
  padding-top: 0;
}

.project:last-child {
  border-bottom: none;
}

.project-link {
  display: block;
  text-decoration: none;
  margin: 0 calc(var(--space-md) * -1);
  padding: var(--space-md);
  border-radius: 6px;
  transition: background-color var(--transition);
}

.project-link:hover {
  text-decoration: none;
  background-color: var(--bg-hover);
}

.project-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-md);
  margin-bottom: var(--space-xs);
}

.project-title {
  font-size: var(--text-base);
  font-weight: var(--weight-medium);
  color: var(--text-primary);
  min-width: 0;
}

.project-tech {
  display: flex;
  gap: var(--space-xs);
  flex-shrink: 0;
  min-width: 0;
}

.tag {
  font-size: var(--text-xs);
  font-family: var(--font-mono);
  color: var(--tag-text);
  background: var(--tag-bg);
  padding: 2px 8px;
  border-radius: 3px;
  white-space: nowrap;
  max-width: 100%;
}

.project-desc {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.5;
  overflow-wrap: anywhere;
}

/* Certification rows */
.cert-list {
  display: flex;
  flex-direction: column;
}

.cert {
  padding: var(--space-md) 0;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-md);
}

.cert:first-child {
  padding-top: 0;
}

.cert:last-child {
  border-bottom: none;
}

.cert-link {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  width: 100%;
  text-decoration: none;
  margin: 0 calc(var(--space-md) * -1);
  padding: var(--space-sm) var(--space-md);
  border-radius: 6px;
  transition: background-color var(--transition);
}

.cert-link:hover {
  text-decoration: none;
  background-color: var(--bg-hover);
}

.cert-name {
  font-size: var(--text-base);
  font-weight: var(--weight-normal);
  color: var(--text-primary);
  min-width: 0;
}

.cert-meta {
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  white-space: nowrap;
}


/* Responsive adjustments */
@media (max-width: 640px) {
  .project {
    padding: var(--space-sm) 0;
  }

  .project-link,
  .cert-link {
    margin: 0;
    padding: var(--space-md) 0;
    border-radius: 0;
  }

  .project-header {
    flex-direction: column;
    gap: var(--space-xs);
    align-items: flex-start;
  }

  .project-tech {
    flex-wrap: wrap;
    width: 100%;
  }

  .cert-link {
    flex-direction: column;
    gap: var(--space-xs);
    align-items: flex-start;
  }

  .cert {
    padding: var(--space-sm) 0;
    display: block;
  }

  .cert-meta {
    white-space: normal;
  }
}

@media (max-width: 380px) {
  .tag {
    white-space: normal;
  }
}
