/* css/sections/team.css */

/* =========================
   TEAM - Команда врачей
   ========================= */

.team{
  padding:80px 0;
  background:#fff;
}

.team__header{
  text-align:center;
  margin-bottom:44px;
}

.team__title{
  font-size:var(--text-5xl);
  font-weight:var(--font-black);
  color:var(--primary-dark);
  margin:0 0 10px;
  font-family:var(--font-display);
  letter-spacing:-1px;
  line-height:1.12;
}

.team__subtitle{
  font-size:var(--text-base);
  color:var(--text-muted);
  margin:0;
  font-weight:var(--font-semibold);
}

.team__layout{
  display:grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap:20px;
  align-items:stretch;
  max-width:1300px;
  margin:0 auto;
}

/* =========================
   Общий стиль карточек
   ========================= */

.doctor{
  border-radius:20px;
  overflow:hidden;
  position:relative;
  background:linear-gradient(135deg, #e8ede8, #f0f4f0);
  border:1px solid rgba(31,138,112,.15);
  box-shadow:
    0 18px 45px rgba(17,24,39,.10),
    0 2px 10px rgba(17,24,39,.06);
  transition:
    transform var(--transition-slow),
    box-shadow var(--transition-slow),
    border-color var(--transition-slow);
}

.doctor:hover{
  transform:translateY(-4px);
  box-shadow:
    0 26px 60px rgba(17,24,39,.14),
    0 4px 14px rgba(17,24,39,.08);
  border-color:rgba(31,138,112,.35);
}

.doctor__media{
  position:relative;
  background:transparent;
  overflow:hidden;
}

.doctor__media img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center top;
}

.doctor__body{
  padding:28px;
}

.doctor__head{
  margin-bottom:20px;
}

.doctor__name{
  margin:0 0 8px;
  line-height:1.15;
  font-weight:var(--font-black);
  color:var(--primary-dark);
  font-family:var(--font-display);
  word-wrap:break-word;
}

.doctor__role{
  margin:0;
  color:var(--text-muted);
  font-weight:var(--font-semibold);
  font-size:16px;
  line-height:1.3;
}

/* =========================
   Главный врач — фото может выходить за края
   ========================= */

.featured{
  display:grid;
  grid-template-columns: 340px 1fr;
  background:linear-gradient(135deg, #e8ede8, #f0f4f0);
  gap:0;
  overflow:visible;
}

.featured .doctor__media{
  height:100%;
  min-height:420px;
  background:transparent;
  overflow:visible;
  z-index:1;
}

.featured .doctor__media img{
  object-fit:cover;
  object-position:center center;

  width:calc(100% + 56px);
  height:100%;
  max-width:none;

  position:relative;
  left:-28px;
}

.featured .doctor__body{
  position:relative;
  z-index:2;
  padding:32px 28px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-width:0;
}

.featured .doctor__name{
  font-size:36px;
  letter-spacing:-.9px;
  margin-bottom:10px;
}

.featured .doctor__role{
  font-size:18px;
}

/* =========================
   Достижения
   ========================= */

.doctor__facts{
  list-style:none;
  padding:0;
  margin:24px 0 0;
  display:flex;
  flex-direction:column;
  gap:16px;
}

.fact{
  display:flex;
  align-items:flex-start;
  gap:12px;
}

.fact::before{
  content:'✓';
  width:28px;
  height:28px;
  flex-shrink:0;
  background:linear-gradient(135deg, var(--primary), var(--primary-hover));
  color:#fff;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
  font-weight:var(--font-bold);
  margin-top:2px;
}

.fact__content{
  display:flex;
  align-items:baseline;
  gap:8px;
  flex-wrap:wrap;
}

.fact__num{
  font-family:var(--font-display);
  font-weight:var(--font-black);
  color:var(--primary-dark);
  font-size:22px;
  line-height:1.2;
  letter-spacing:-.4px;
}

.fact__label{
  font-size:16px;
  color:var(--text-muted);
  line-height:1.4;
  font-weight:var(--font-medium);
}

/* =========================
   Правая колонка — медсёстры
   ========================= */

.team__side{
  display:grid;
  grid-template-rows: repeat(3, 1fr);
  gap:20px;
  height:100%;
}

/* ✅ Разрешаем "выход за карточку" как у главного врача */
.mini{
  display:grid;
  grid-template-columns: 130px 1fr;
  align-items:center;
  background:linear-gradient(135deg, #e8ede8, #f0f4f0);
  min-height:0;
  isolation:isolate;

  overflow:visible; /* ключ: чтобы контент мог выходить */
}

/* ✅ медиа тоже должна быть visible */
.mini .doctor__media{
  height:100%;
  min-height:160px;
  overflow:visible; /* ключ */
  z-index:1;
}

/* ✅ делаем картинку шире и сдвигаем наружу */
.mini .doctor__media img{
  object-position:center 18%;

  width:calc(100% + 36px); /* выход за края */
  height:100%;
  max-width:none;

  position:relative;
  left:-18px;
}

.mini .doctor__body{
  padding:22px 22px 22px 18px;
  position:relative;
  z-index:2; /* текст сверху, если фото пересекается */
}

.mini .doctor__name{
  font-size:20px;
  margin:0 0 6px;
  line-height:1.2;
  letter-spacing:-.4px;
}

.mini .doctor__role{
  font-size:15px;
  line-height:1.3;
}

/* =========================
   Responsive
   ========================= */

@media (max-width:980px){
  .team{
    padding:60px 0;
  }

  .team__layout{
    grid-template-columns:1fr;
    gap:24px;
  }

  .featured{
    grid-template-columns:280px 1fr;
  }

  .featured .doctor__media{
    min-height:380px;
  }

  .featured .doctor__media img{
    width:calc(100% + 44px);
    left:-22px;
  }

  .featured .doctor__name{
    font-size:30px;
  }

  .team__side{
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows:none;
    gap:18px;
  }

  .mini{
    grid-template-columns:1fr;
    grid-template-rows:auto 1fr;
  }

  .mini .doctor__media{
    height:260px;
    min-height:260px;
    overflow:hidden; /* на сетке из 3 карточек лучше не "вылезать" */
  }

  .mini .doctor__media img{
    object-position:center 12%;
    width:100%;
    left:0;
    position:static;
  }

  .mini .doctor__body{
    padding:20px;
  }

  .mini .doctor__name{
    font-size:19px;
  }
}

@media (max-width:720px){
  .team{
    padding:50px 0;
  }

  .team__side{
    grid-template-columns:1fr;
  }

  .featured{
    grid-template-columns:1fr;
    overflow:hidden;
  }

  .featured .doctor__media{
    min-height:340px;
    overflow:hidden;
  }

  .featured .doctor__media img{
    width:100%;
    left:0;
  }

  .featured .doctor__name{
    font-size:28px;
  }

  .fact__content{
    flex-direction:column;
    gap:4px;
  }

  .mini{
    overflow:hidden; /* в одну колонку не надо "вылезать" */
  }

  .mini .doctor__media{
    height:280px;
    min-height:280px;
    overflow:hidden;
  }

  .mini .doctor__media img{
    width:100%;
    left:0;
    position:static;
  }
}
