/* Global typography */
body {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  line-height: 1.6;
  color: #222;
}

/* Header overrides */
header {
  background: #e9f2ff; /* softer info-like tone */
  border-bottom: 3px solid #1c4fa0;
  letter-spacing: 2px;
}

h1.title {
    color: #1c3f7c !important;
}

/* About section image */
.media .image img {
  border-radius: 12px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.15);
}

/* Sections */
.section {
  padding-top: 3rem;
  padding-bottom: 3rem;
}

/* Publications message boxes */
.message {
  border: 1px solid #d9e2ef;
  border-radius: 8px;
  box-shadow: 0 2px 4px rgba(0,0,0,0.05);
}

.message-header {
  background: #1c4fa0;
  color: white;
  font-weight: 700;
  border-radius: 6px 6px 0 0 !important;
}

.message-body {
  background: #fff;
  border-radius: 0 0 6px 6px;
}

/* Publication images */
.message-body .image img {
  border-radius: 6px;
  box-shadow: 0 3px 6px rgba(0,0,0,0.12);
}

/* Buttons */
.button {
  margin-right: 0.5rem;
  margin-top: 0.5rem;
  border-radius: 6px;
  font-weight: 600;
}

/* Links inside body text */
.media-content a {
  color: #1c4fa0;
  text-decoration: underline;
}

.media-content a:hover {
  color: #163b7a;
}

/* Publication summary spacing */
.message-body p {
  margin-bottom: 1rem;
}

.about-section {
  background: #f9fafc; /* very light grey/blue */
  padding: 3rem 1rem;
  border-radius: 8px;
}

.roles {
  margin-top: 1rem;
  list-style: none;
  padding-left: 0;
}

.roles li {
  margin-bottom: 0.4rem;
}

.roles strong {
  color: #1c4fa0;
}

.profile-photo {
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}