/* --- ALAPBEÁLLÍTÁSOK ÉS DINAMIKUS HÁTTÉR --- */
body {
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  background: linear-gradient(135deg, #0366d6 0%, #67cef7 100%);
  min-height: 100vh;
  position: relative;
  overflow-x: hidden;
  margin: 0;
  padding: 0;
}

body::before {
  content: "";
  position: fixed; 
  inset: 0; 
  z-index: -1;
  background: url('../images/hatter.jpg') center center / cover no-repeat;
  opacity: 0.15;
  pointer-events: none;
}

.cs-header { 
  text-shadow: 0 3px 15px rgba(0, 50, 108, 0.5); 
  font-size: clamp(1.8rem, 5vw, 2.8rem); /* Dinamikusan méreteződő cím */
  font-weight: 800;
  color: #ffffff;
  text-align: center;
  margin: 2rem 0;
}

/* --- KÁRTYA ELRENDEZÉS (EGYFORMA MAGASSÁG) --- */
.row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

/* Bootstrap oszlopok kényszerítése azonos magasságra */
.col-md-4, .col-sm-6, .col-12 {
  display: flex;
  margin-bottom: 30px;
}

/* --- A CSAPAT KÁRTYA STÍLUSA --- */
.team-card {
  background: rgba(255, 255, 255, 0.98);
  border-radius: 1.25rem;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  width: 100%;
  border: none;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12);
  transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275), box-shadow 0.3s ease;
  
  /* Belépő animáció */
  animation: fadeInCard 0.6s ease-out forwards;
  opacity: 0;
}

.team-card:hover { 
  box-shadow: 0 15px 40px rgba(3, 102, 214, 0.4); 
  transform: translateY(-10px);
}

/* --- KÉP KEZELÉSE (NEM VÁGJA LE A SZÉLEKET) --- */
.card-img-top {
  width: 100%;
  /* A 16:9 vagy 3:2 arány biztosítja, hogy a csoportképek szélessége megmaradjon */
  aspect-ratio: 16 / 10; 
  object-fit: cover;     /* Kitölti a keretet */
  object-position: center 20%; /* Kicsit feljebb tolja a fókuszt az arcokra */
  border-bottom: 4px solid #ffcb05;
  display: block;
}

/* --- TARTALOM ÉS SZÖVEG --- */
.card-body {
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  flex-grow: 1; /* Ez tolja ki a kártyát, hogy minden alja egy vonalba kerüljön */
}

.card-title { 
  font-weight: 800; 
  color: #073263; 
  margin-bottom: 0.3rem;
  font-size: 1.25rem;
}

.card-subtitle { 
  font-weight: 600;
  color: #0366d6;
  text-transform: uppercase;
  font-size: 0.8rem;
  letter-spacing: 1px;
  margin-bottom: 1rem;
}

.card-text {
  color: #2d3748;
  font-size: 1rem;
  line-height: 1.5;
  margin-bottom: 0;
}

/* --- ANIMÁCIÓ DEFINÍCIÓ --- */
@keyframes fadeInCard {
  from { opacity: 0; transform: translateY(30px); }
  to { opacity: 1; transform: translateY(0); }
}

/* --- RESZPONZÍV BEÁLLÍTÁSOK (MOBIL ÉS TABLET) --- */

@media (max-width: 992px) {
  .card-img-top {
    aspect-ratio: 16 / 11; /* Tableten kicsit magasabb képkeret */
  }
}

@media (max-width: 768px) {
  .col-sm-6 {
    padding: 10px; /* Több hely a kártyák között mobilon */
  }
  
  .card-img-top {
    /* Mobilon a 4:3-as arány a legbiztonságosabb, hogy mindenki látszódjon */
    aspect-ratio: 4 / 3; 
  }

  .card-body {
    padding: 1.2rem;
  }
}

@media (max-width: 480px) {
  .card-img-top {
    aspect-ratio: 3 / 2; /* Nagyon kicsi kijelzőn kicsit laposabb kép */
  }
  
  .card-title {
    font-size: 1.15rem;
  }
}