/* ==========================================================================
   About Page
   ========================================================================== */

/* --- About Section --- */

.about {
  padding-top: calc(var(--nav-height) + var(--space-16));
}

.about__grid {
  display: grid;
  grid-template-columns: 2fr 3fr;
  gap: var(--space-16);
  align-items: start;
}

.about__photo {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  border-radius: var(--border-radius);
}

.about__title {
  font-size: var(--text-2xl);
  margin-bottom: var(--space-8);
}

.about__bio p {
  color: var(--color-text-primary);
  line-height: 1.7;
}

.about__section {
  margin-top: var(--space-10);
  padding-top: var(--space-10);
  border-top: 1px solid var(--color-border);
}

.about__section-title {
  font-size: var(--text-xl);
  margin-bottom: var(--space-4);
}

/* --- Education --- */

.edu-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.edu-item {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: var(--space-4);
  align-items: start;
}

.edu-item__year {
  font-size: var(--text-sm);
  color: var(--color-text-tertiary);
  padding-top: 2px;
  font-family: var(--font-body);
}

.edu-item__school {
  font-weight: 600;
  color: var(--color-text-primary);
  font-family: var(--font-display);
}

.edu-item__degree {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  margin-top: var(--space-1);
}

.edu-item__honors {
  list-style: none;
  margin-top: var(--space-2);
}

.edu-item__honors li {
  font-size: var(--text-xs);
  color: var(--color-text-tertiary);
  line-height: 1.8;
}

/* --- Experience --- */

.exp-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.exp-item {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: var(--space-4);
  align-items: start;
}

.exp-item__period {
  font-size: var(--text-sm);
  color: var(--color-text-tertiary);
  padding-top: 2px;
  font-family: var(--font-body);
}

.exp-item__company {
  font-weight: 600;
  color: var(--color-text-primary);
  font-family: var(--font-display);
}

.exp-item__role {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  margin-top: var(--space-1);
}

/* --- Tools Grid --- */

.tools-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-3);
}

.tool-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2);
}

.tool-card__icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.tool-card__icon img {
  width: 40px;
  height: 40px;
  display: block;
}

.tool-card--catia .tool-card__icon {
  width: 100%;
  justify-content: center;
}

.tool-card--catia .tool-card__icon img {
  width: auto;
  height: 28px;
}

.tool-card__name {
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
  text-align: center;
  font-family: var(--font-body);
  line-height: 1.3;
}

@media (max-width: 767px) {
  .about__grid {
    grid-template-columns: 1fr;
    gap: var(--space-10);
  }

  .about__photo {
    max-width: 320px;
    margin: 0 auto;
    display: block;
  }

  .edu-item,
  .exp-item {
    grid-template-columns: 1fr;
    gap: var(--space-1);
  }

  .edu-item__year,
  .exp-item__period {
    font-size: var(--text-xs);
  }

  .tools-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-2);
  }

  .tool-card {
    padding: var(--space-1);
  }
}

/* --- Contact Section --- */

.contact {
  padding-block: var(--space-20);
}

.contact__inner {
  max-width: 600px;
}

.contact__title {
  font-size: var(--text-2xl);
  margin-bottom: var(--space-4);
}

.contact__text {
  color: var(--color-text-secondary);
  margin-bottom: var(--space-8);
}

.contact__links {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.contact__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-base);
  font-weight: 500;
  color: var(--color-text-primary);
  transition: color var(--duration-fast) var(--ease-out);
  cursor: pointer;
}

.contact__link:hover {
  color: var(--color-accent);
}

.contact__link svg {
  flex-shrink: 0;
}
