/* Kontakty – matched to https://csm-vrchlabi.cz/kontakty */

/* Hero in nav – scoped to kontakty block classes only */
.csm-nav__action:has(.csm-kontakt-hero__btn) {
    flex-direction: column;
    text-align: center;
}

.csm-kontakt-hero__title {
    margin: 0 0 5rem;
    font-size: 2.5rem;
    font-weight: 700;
    color: #fff;
    line-height: 1.2;
}

.csm-kontakt-hero__btn {
    display: inline-block;
    padding: 0.75rem 1.5rem;
    font-size: 1.5rem;
    font-weight: 600;
    line-height: 1.5;
    text-decoration: none;
    color: rgba(0, 0, 0, 0.7);
    background-color: #c8d400;
    border: 2px solid transparent;
    cursor: pointer;
    transition: background-color 0.2s, color 0.2s;
}

.csm-kontakt-hero__btn:hover {
    background-color: #bcc700;
    color: rgba(0, 0, 0, 0.7);
}

.csm-kontakt {
    padding: 2.5rem 0 3.75rem;
}

.csm-kontakt__panel {
    display: flex;
    flex-wrap: wrap;
    margin: 0 -0.75rem;
}

.csm-kontakt__info-col {
    box-sizing: border-box;
    width: 100%;
    padding: 0 0.75rem;
}

@media screen and (min-width: 769px) {
    .csm-kontakt__info-col {
        width: 33.3333%;
    }

    .csm-kontakt__map-col {
        width: 66.6667%;
    }
}

.csm-kontakt__map-col {
    box-sizing: border-box;
    padding: 0 0.75rem;
    min-height: 18.75rem;
}

.csm-kontakt__map {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 18.75rem;
    border: none;
}

.csm-kontakt__info-block {
    margin-bottom: 1.875rem;
}

.csm-kontakt__info-block:last-child {
    margin-bottom: 0;
}

/* Subtitle with grey underline (info + team member names) */
.csm-kontakt__subtitle.line-after {
    position: relative;
    margin: 0 0 1.25rem;
    font-size: 1.25rem;
    font-weight: 700;
    color: #fff;
}

.csm-kontakt__subtitle.line-after::after {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    bottom: -0.625rem;
    width: 2.5rem;
    border-bottom: 0.125rem solid #707070;
}

.csm-kontakt__content,
.csm-kontakt__content p {
    margin: 0 0 0.5rem;
    color: #fff;
    font-size: 1rem;
    line-height: 1.5;
}

.csm-kontakt__content p:last-child {
    margin-bottom: 0;
}

.csm-kontakt__content a {
    color: #fff;
    text-decoration: none;
}

.csm-kontakt__content a:hover {
    color: #c8d400;
}

.csm-kontakt__content strong {
    font-weight: 700;
}

.csm-kontakt__team-heading {
    margin: 2.5rem 0 3.125rem;
}

.csm-kontakt__team-heading .csm-section-heading__title {
    font-size: 1.75rem;
}

.csm-kontakt__team {
    display: flex;
    flex-wrap: wrap;
    margin: 0 -0.75rem;
}

.csm-kontakt__member {
    display: flex;
    box-sizing: border-box;
    width: 100%;
    padding: 0 0.75rem;
    margin-bottom: 2.5rem;
}

@media screen and (min-width: 1408px) {
    .csm-kontakt__member {
        width: 40%;
        margin-left: 8.3333%;
    }
}

.csm-kontakt__member-photo {
    position: relative;
    flex-shrink: 0;
    width: 50%;
    max-width: 12.5rem;
    margin: 0;
}

.csm-kontakt__member-photo::after {
    content: "";
    display: block;
    padding-bottom: 100%;
}

.csm-kontakt__member-photo [cw-b-img],
.csm-kontakt__member-photo img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.csm-kontakt__member-desc {
    padding-left: 1.25rem;
    min-width: 0;
}
