/* === Базовые сбросы === */
*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body {
    font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
    background-color: #e8edf2;
    /* Flexbox для центрирования карточки по центру экрана */
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    padding: 20px;
}

/* === Карточка === */
.card {
    background: #ffffff;
    border-radius: 16px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
    /* Включаем flex для горизонтальной раскладки фото+инфо */
    display: flex;
    /* Если экран узкий, элементы могут переноситься (мы добавим адаптив позже) */
    flex-wrap: wrap;
    max-width: 700px;
    width: 100%;
    overflow: hidden; /* чтобы border-radius сработал на дочерних элементах */
}

/* === Фото === */
.card__photo {
    /* Базовый размер 200px, но может сжиматься/растягиваться */
    flex: 1 1 200px;
    min-width: 150px;
    /* Чтобы изображение внутри обрезалось правильно, если оно не квадратное */
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f0f4f8;
}

.card__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* изображение заполнит блок, обрезая лишнее, сохраняя пропорции */
    display: block;
}

/* === Информация === */
.card__info {
    flex: 2 1 300px; /* занимает вдвое больше места, чем фото, но минимум 300px */
    padding: 30px 30px 30px 35px;
    display: flex;
    flex-direction: column;
    justify-content: center; /* вертикальное центрирование текстового блока */
}

.card__name {
    font-size: 2rem;
    color: #1a2b3c;
    margin-bottom: 0.2em;
    font-weight: 700;
}

.card__title {
    font-size: 1rem;
    color: #5e6f82;
    margin-bottom: 1em;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.card__description {
    font-size: 0.95rem;
    line-height: 1.5;
    color: #3a4a5a;
    margin-bottom: 1.5em;
}

/* === Контакты === */
.card__contacts {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 10px; /* отступ между пунктами */
}

.card__contacts li {
    display: flex;
    align-items: center;
    gap: 8px;
}

.contact-icon {
    font-size: 1.2rem;
    width: 24px;
    text-align: center;
}

.card__contacts a {
    text-decoration: none;
    color: #2c5f8a;
    font-weight: 500;
    transition: color 0.2s;
}

.card__contacts a:hover {
    color: #1e3f5f;
    text-decoration: underline;
}