/* Projects page cards - uses existing CSS variables for dark mode compatibility */

.projects-grid {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: center;
  gap: 28px;
}

.project-card {
  width: 30%;
  min-width: 200px;
  background: var(--background);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.06);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.project-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 30px rgba(0,0,0,0.10);
  border-color: rgba(63,129,229,0.25);
}

.project-media {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 160px;
  background: var(--card-color);
}
.project-media img {
  max-height: 120px;
  max-width: 90%;
  object-fit: contain;
}

.project-body { padding: 18px 20px 16px; display: flex; flex-direction: column; flex: 1 1 auto; }

.project-title {
  font-size: var(--font-subtitle-size);
  font-weight: 600;
  color: var(--text);
  margin: 0 0 6px;
  min-height: 2.4em; /* reserve space for up to 2 lines to align rows */
}
.project-meta {
  color: var(--secondary-color);
  font-size: var(--font-abstract-size);
  font-style: italic;
  margin: 0 0 10px;
  min-height: 1.4em; /* align start of description across cards */
}
.project-desc {
  color: var(--secondary-text);
  font-size: var(--font-description-size, 0.95rem);
  line-height: 1.45;
  margin: 0 0 14px;
  flex: 1 1 auto; /* occupy remaining space so actions align at bottom */
}

.project-links { display: flex; gap: 10px; flex-wrap: wrap; }
.project-links a {
  color: var(--primary-color);
  text-decoration: none;
  font-size: var(--font-abstract-size);
}
.project-links a:hover { text-decoration: underline; }

/* Button (optional) */
.project-actions { padding: 0 20px 20px; }
.project-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--background);
  color: var(--primary-color);
  border: 2px solid var(--primary-color);
  border-radius: 10px;
  padding: 10px 14px;
  text-decoration: none;
  font-weight: 500;
  transition: background .2s ease, color .2s ease, transform .2s ease, box-shadow .2s ease;
}
.project-btn:hover {
  background: var(--primary-color);
  color: var(--background);
  transform: translateY(-2px);
  box-shadow: 0 10px 18px rgba(63,129,229,0.25);
}

/* Small screens: tweak media height and spacing */
@media (max-width: 680px) {
  .project-media { height: 140px; }
  .project-media img { max-height: 100px; }
  .project-body { padding: 16px 16px 14px; }
}


/*@media screen and (max-width: 1000px) {
    main {
        padding: 20px 7%;
        height: auto;
    }

    .education-level{
        flex : 1 1 calc(50% - 10px);
        max-width: 100%;
    }
}