a:any-link {
  text-decoration-line: underline;
  text-decoration-thickness: max(1px, 0.08em);
  text-underline-offset: 0.16em;
}

a:any-link:hover {
  text-decoration-thickness: max(2px, 0.12em);
}

a:any-link:focus-visible {
  outline: 2px solid var(--cyan);
  outline-offset: 2px;
  border-radius: 4px;
}

.site-nav a,
.footer-links a,
.button,
.wireframe-link,
.nav-cta {
  text-decoration: none;
}

.cv-contact {
  gap: 8px;
}

.cv-achievements-card {
  height: 100%;
}

.cv-achievements-card .cv-role-bullets {
  margin-top: 12px;
}

.cv-achievements-card .cv-role-bullets li {
  font-size: 0.95rem;
  line-height: 1.6;
}

.cv-achievements-card .cv-role-bullets li + li {
  margin-top: 6px;
}

.cv-contact-strip {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.cv-contact-strip .cv-contact-compact {
  padding: 12px 14px;
}

.cv-contact-strip .cv-contact-compact strong {
  margin-top: 4px;
  line-height: 1.3;
}

@media (max-width: 980px) {
  .cv-contact-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 700px) {
  .cv-contact-strip {
    grid-template-columns: 1fr;
  }
}
