/* projects */

#projects h3 {
    color: var(--text-secondary-color) !important;
}

#projects a {
    text-decoration: none;
    color: var(--text-link-color) !important;
}

#projects .badge {
  background-color: var(--secondary-background-color) !important;
  color: var(--text-color) !important;
  border: 1px solid color-mix(in srgb, var(--text-color) 14%, transparent);
  margin: 0 1%;
}

#projects .card {
    background-color: var(--secondary-color) !important;
    box-shadow: 0px 8px 56px rgb(15 80 100 / 16%);
    min-height: 400px;
    overflow: hidden;
    border-radius: 1rem;
    border: none !important;
}

#projects .card:hover {
    box-shadow: 0 0 11px rgb(15 80 100 / 20%);
    transition: transform 0.3s;
    transform: translateY(-7px);
}

#projects .card .card-head {
    height: 200px;            /* ← THIS was missing */
    overflow: hidden;
    border-top-left-radius: 1rem;
    border-top-right-radius: 1rem;
}

#projects .card .card-footer {
    border-bottom-left-radius: 1rem;
    border-bottom-right-radius: 1rem;
}

#projects .card:hover .card-img-top {
    transform: scale(1.08);
    transition: transform 0.3s ease-out;
}

#projects .card-img-top {
    width: 100%;
    height: 100%;
    object-fit: cover;        /* ← belongs here */
    object-position: center;
    transition: transform 0.3s;
    display: block;
}

#projects .float-end .btn {
    transition: none;
    border-radius: .5rem !important;
    border-color: var(--primary-color) !important;
}

#projects .float-end .btn:focus {
    box-shadow: none !important;
}

#projects .carousel {
  position: relative;
}

#projects .carousel-inner {
  padding: 0 2.75rem; /* room for arrows */
}

#projects .carousel-control-prev,
#projects .carousel-control-next {
  width: 2.75rem;
  opacity: 1;
}

#projects .carousel-control-prev {
  left: 0;
}

#projects .carousel-control-next {
  right: 0;
}

/* Make arrows match theme */
#projects .carousel-control-prev-icon,
#projects .carousel-control-next-icon {
  background-image: none;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 999px;
  background-color: var(--secondary-color);
  border: 1px solid color-mix(in srgb, var(--text-color) 18%, transparent);
  position: relative;
}

/* Custom chevrons */
#projects .carousel-control-prev-icon::after,
#projects .carousel-control-next-icon::after {
  content: "";
  display: block;
  width: 0.55rem;
  height: 0.55rem;
  border-right: 2px solid var(--text-color);
  border-bottom: 2px solid var(--text-color);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-35%, -50%) rotate(135deg);
}

#projects .carousel-control-next-icon::after {
  transform: translate(-65%, -50%) rotate(-45deg);
}

/* Hover */
#projects .carousel-control-prev:hover .carousel-control-prev-icon,
#projects .carousel-control-next:hover .carousel-control-next-icon {
  border-color: color-mix(in srgb, var(--primary-color) 55%, transparent);
}

/* Mobile: remove side padding so cards are not squeezed */
@media (max-width: 768px) {
  #projects .carousel-inner {
    padding: 0 1.75rem;
  }
  #projects .carousel-control-prev,
  #projects .carousel-control-next {
    width: 1.75rem;
  }
  #projects .carousel-control-prev-icon,
  #projects .carousel-control-next-icon {
    width: 1.9rem;
    height: 1.9rem;
  }
}

@media (max-width: 992px) {
  #projects .card .card-head { height: 180px; }
}

@media (max-width: 576px) {
  #projects .card .card-head { height: 160px; }
}