/* ================================================================
   md/team – Design System
   ================================================================ */

:root {
    --team-green:       #7f852f;
    --team-green-light: #e7e9cd;
    --team-green-dark:  #4a4f1a;
    --team-border:      #dde0b5;
    --team-bg-tint:     #fafbf2;
    --team-muted:       #6c757d;
    --team-shadow:      0 4px 16px rgba(127, 133, 47, 0.12);
    --team-shadow-lg:   0 8px 24px rgba(127, 133, 47, 0.18);
}

.md-team { font-family: inherit; }

.md-team__title {
    font-size: 1.3rem;
    font-weight: 600;
    color: #2c2c2c;
    border-left: 4px solid var(--team-green);
    padding-left: 0.8rem;
    margin-bottom: 1.75rem;
}

/* ----------------------------------------------------------------
   Kontakt-Buttons
   ---------------------------------------------------------------- */
.md-team-contact-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.32rem 0.75rem;
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    border: 1px solid var(--team-border);
    border-radius: 2px;
    color: #444;
    background: #fff;
    text-decoration: none;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.07);
    transition: background 0.18s, color 0.18s, border-color 0.18s,
                transform 0.18s, box-shadow 0.18s;
    cursor: pointer;
    white-space: nowrap;
}
.md-team-contact-btn:hover {
    background: var(--team-green);
    border-color: var(--team-green);
    color: #fff;
    transform: translateY(-1px);
    box-shadow: 0 4px 10px rgba(127, 133, 47, 0.28);
}
.md-team-contact-btn svg { flex-shrink: 0; }

/* ================================================================
   GRID – Horizontal card (image left, text right)
   ================================================================ */

.md-team-grid-card {
    display: flex;
    background: #fff;
    border: 1px solid var(--team-border);
    overflow: hidden;
    height: 100%;
    min-height: 180px;
    transition: background 0.25s, box-shadow 0.25s;
}
.md-team-grid-card:hover {
    background: var(--team-bg-tint);
    box-shadow: var(--team-shadow);
}

/* Image column – fixed width, stretches to card height */
.md-team-grid-card__img-col {
    flex-shrink: 0;
    width: 140px;
    position: relative;
    overflow: hidden;
    background: var(--team-green-light);
}
.md-team-grid-card__img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    display: block;
    transition: transform 0.4s ease;
}
.md-team-grid-card:hover .md-team-grid-card__img { transform: scale(1.06); }

/* Text column */
.md-team-grid-card__body {
    flex: 1;
    min-width: 0;
    padding: 0.7rem 0.85rem;
    overflow-wrap: break-word;
    display: flex;
    flex-direction: column;
    justify-content: center;
    border-left: 3px solid transparent;
    transition: border-left-color 0.25s;
}
.md-team-grid-card:hover .md-team-grid-card__body {
    border-left-color: var(--team-green);
}
.md-team-grid-card__name {
    font-size: 1rem;
    font-weight: 600;
    color: #2c2c2c;
    margin-bottom: 0.2rem;
    line-height: 1.3;
}
.md-team-grid-card__fn {
    font-size: 0.88rem;
    color: var(--team-muted);
    margin: 0;
    line-height: 1.45;
}
.md-team-grid-card__contact {
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem;
    margin-top: 0.55rem;
}

@media (max-width: 767.98px) {
    .md-team-grid-card__img-col { width: 100px; }
    .md-team-grid-card { min-height: 140px; }
}

/* ================================================================
   GRID CLASSIC – Card with image on top
   ================================================================ */

.md-team-card-classic {
    background: #fff;
    border: 1px solid var(--team-border);
    overflow: hidden;
    height: 100%;
    display: flex;
    flex-direction: column;
    transition: box-shadow 0.25s, transform 0.25s;
}
.md-team-card-classic:hover {
    box-shadow: var(--team-shadow-lg);
    transform: translateY(-3px);
}

.md-team-card-classic__img-wrap {
    height: 220px;
    overflow: hidden;
    background: var(--team-green-light);
    flex-shrink: 0;
    position: relative;
}

/* blurred background – same image, cover + blur */
.md-team-card-classic__img-blur {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    filter: blur(14px) brightness(0.78);
    transform: scale(1.12);
    transition: transform 0.5s ease;
}
.md-team-card-classic:hover .md-team-card-classic__img-blur { transform: scale(1.18); }

/* sharp foreground – full image, contain */
.md-team-card-classic__img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center;
    display: block;
    transition: transform 0.4s ease;
}
.md-team-card-classic:hover .md-team-card-classic__img { transform: scale(1.03); }

.md-team-card-classic__body {
    padding: 0.7rem 0.85rem 0.85rem;
    flex: 1;
    display: flex;
    flex-direction: column;
    border-top: 2px solid transparent;
    transition: border-top-color 0.25s;
}
.md-team-card-classic:hover .md-team-card-classic__body {
    border-top-color: var(--team-green);
}

.md-team-card-classic__name {
    font-size: 1rem;
    font-weight: 600;
    color: #2c2c2c;
    margin-bottom: 0.2rem;
    line-height: 1.3;
}
.md-team-card-classic__fn {
    font-size: 0.88rem;
    color: var(--team-muted);
    margin: 0;
    line-height: 1.45;
}
.md-team-card-classic__contact {
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem;
    margin-top: auto;
    padding-top: 0.5rem;
}

/* ================================================================
   LIST – Staff Directory
   ================================================================ */

.md-team-list { display: flex; flex-direction: column; }

.md-team-list__item {
    display: flex;
    align-items: center;
    gap: 1.1rem;
    padding: 0.85rem 1rem;
    background: #fff;
    border-bottom: 1px solid var(--team-border);
    border-left: 3px solid transparent;
    transition: border-left-color 0.22s, background 0.22s, box-shadow 0.22s;
}
.md-team-list__item:first-child { border-top: 1px solid var(--team-border); }
.md-team-list__item:hover {
    border-left-color: var(--team-green);
    background: var(--team-bg-tint);
    box-shadow: inset 4px 0 0 var(--team-green),
                0 2px 12px rgba(127, 133, 47, 0.08);
}

.md-team-list__img-wrap {
    flex-shrink: 0;
    width: 64px;
    height: 64px;
    border-radius: 50%;
    overflow: hidden;
    background: var(--team-green-light);
    border: 2px solid var(--team-border);
    transition: border-color 0.22s, box-shadow 0.22s;
}
.md-team-list__item:hover .md-team-list__img-wrap {
    border-color: var(--team-green);
    box-shadow: 0 0 0 3px rgba(127, 133, 47, 0.15);
}
.md-team-list__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.35s ease;
}
.md-team-list__item:hover .md-team-list__img { transform: scale(1.1); }

.md-team-list__body {
    flex: 1;
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
}
.md-team-list__meta { flex: 1; min-width: 0; }
.md-team-list__contact { display: flex; gap: 0.4rem; flex-shrink: 0; }

.md-team-list__name {
    font-size: 1rem;
    font-weight: 600;
    color: #2c2c2c;
    margin-bottom: 0.2rem;
    line-height: 1.3;
}
.md-team-list__fn {
    font-size: 0.88rem;
    color: var(--team-muted);
    font-weight: 400;
    margin: 0;
    line-height: 1.45;
}

@media (max-width: 575px) {
    .md-team-list__item { flex-wrap: wrap; }
    .md-team-list__body { flex-direction: column; align-items: flex-start; }
    .md-team-list__contact { margin-top: 0.35rem; }
}

/* ================================================================
   COMPACT – Table directory
   ================================================================ */

.md-team-compact tbody tr { transition: background 0.15s; }
.md-team-compact tbody tr:hover { background: var(--team-bg-tint) !important; }
.md-team-compact td { vertical-align: middle; }
.md-team-compact .md-team-compact__name {
    font-size: 0.88rem;
    font-weight: 600;
    color: #2c2c2c;
}
.md-team-compact .md-team-compact__functions {
    font-size: 0.78rem;
    color: var(--team-muted);
}
