/* ==========================================================================
   Cards Component
   ========================================================================== */

/* ---- Base Card ---- */
.card {
    background-color: var(--color-white);
    border-radius: var(--border-radius);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

/* ---- Service Card ---- */
/* Mockup: content on top, image on bottom. Card has border, rounded corners. */
.service-card {
    display: flex;
    flex-direction: column;
    border-radius: var(--border-radius);
    border: 1px solid rgba(9, 9, 8, 0.15);
    overflow: hidden;
    background-color: var(--color-background-light);
    transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.service-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

.service-card__image {
    aspect-ratio: 296 / 171;
    overflow: hidden;
}

.service-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.service-card:hover .service-card__image img {
    transform: scale(1.05);
}

.service-card__content {
    padding: var(--space-lg);
    display: flex;
    flex-direction: column;
    flex: 1;
}

.service-card__title {
    font-size: var(--fs-2xl);
    font-weight: var(--fw-medium);
    margin-bottom: var(--space-sm);
}

.service-card__title a {
    color: var(--color-text-dark);
}

.service-card__title a:hover {
    color: var(--color-sage);
}

.service-card__description {
    font-size: var(--fs-md);
    color: var(--color-text-dark);
    line-height: var(--lh-relaxed);
    margin-bottom: var(--space-md);
    flex: 1;
}

.service-card__link {
    font-size: var(--fs-md);
    font-weight: var(--fw-medium);
    color: var(--color-text-dark);
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
    text-decoration: none;
    transition: color var(--transition-fast);
}

.service-card__link svg {
    transition: transform var(--transition-fast);
}

.service-card__link:hover {
    color: var(--color-sage);
}

.service-card__link:hover svg {
    transform: translateX(4px);
}

/* ---- Condition Card ---- */
.condition-card {
    display: flex;
    flex-direction: column;
}

.condition-card__image {
    aspect-ratio: 16 / 10;
    overflow: hidden;
}

.condition-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.condition-card:hover .condition-card__image img {
    transform: scale(1.05);
}

.condition-card__content {
    padding: var(--space-lg);
    display: flex;
    flex-direction: column;
    flex: 1;
}

.condition-card__title {
    font-size: var(--fs-lg);
    margin-bottom: var(--space-sm);
}

.condition-card__description {
    font-size: var(--fs-sm);
    color: var(--color-text-muted);
    line-height: var(--lh-relaxed);
    margin-bottom: var(--space-md);
    flex: 1;
}

.condition-card__link {
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    color: var(--color-sage);
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.condition-card__link::after {
    content: '→';
    transition: transform var(--transition-fast);
}

.condition-card__link:hover::after {
    transform: translateX(4px);
}

/* ---- Team Card ---- */
.team-card {
    text-align: center;
    padding: var(--space-xl);
}

.team-card__avatar {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    margin: 0 auto var(--space-md);
    overflow: hidden;
    background-color: var(--color-background-warm);
}

.team-card__avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.team-card__avatar-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-heading);
    font-size: var(--fs-3xl);
    font-weight: var(--fw-medium);
    color: var(--color-sage);
    background-color: var(--color-background-warm);
}

.team-card__name {
    font-size: var(--fs-lg);
    margin-bottom: var(--space-xs);
}

.team-card__role {
    font-size: var(--fs-sm);
    color: var(--color-sage);
    font-weight: var(--fw-medium);
    margin-bottom: var(--space-sm);
}

.team-card__bio {
    font-size: var(--fs-sm);
    color: var(--color-text-muted);
    line-height: var(--lh-relaxed);
    margin-bottom: var(--space-md);
}

.team-card__socials {
    display: flex;
    justify-content: center;
    gap: var(--space-sm);
}

.team-card__social-link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background-color: var(--color-background-light);
    color: var(--color-text-dark);
    transition: background-color var(--transition-fast), color var(--transition-fast);
}

.team-card__social-link:hover {
    background-color: var(--color-sage);
    color: var(--color-white);
}

.team-card__social-link svg {
    width: 16px;
    height: 16px;
}

/* ---- Highlight Card (Service highlights on About page) ---- */
.highlight-card {
    padding: var(--space-xl);
    text-align: center;
    background-color: var(--color-white);
    border-radius: var(--border-radius);
}

.highlight-card__icon {
    font-size: var(--fs-3xl);
    margin-bottom: var(--space-md);
}

.highlight-card__title {
    font-size: var(--fs-lg);
    margin-bottom: var(--space-sm);
}

.highlight-card__description {
    font-size: var(--fs-sm);
    color: var(--color-text-muted);
    line-height: var(--lh-relaxed);
}

/* ---- Archive Card (Blog listing) ---- */
.archive-card {
    display: flex;
    flex-direction: column;
}

.archive-card__image {
    aspect-ratio: 16 / 9;
    overflow: hidden;
}

.archive-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.archive-card__content {
    padding: var(--space-lg);
    flex: 1;
    display: flex;
    flex-direction: column;
}

.archive-card__meta {
    font-size: var(--fs-xs);
    color: var(--color-text-muted);
    margin-bottom: var(--space-sm);
}

.archive-card__title {
    font-size: var(--fs-lg);
    margin-bottom: var(--space-sm);
}

.archive-card__title a {
    color: var(--color-text-dark);
}

.archive-card__title a:hover {
    color: var(--color-sage);
}

.archive-card__excerpt {
    font-size: var(--fs-sm);
    color: var(--color-text-muted);
    line-height: var(--lh-relaxed);
    flex: 1;
}

.archive-card__link {
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    color: var(--color-sage);
    margin-top: var(--space-md);
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.archive-card__link::after {
    content: '→';
    transition: transform var(--transition-fast);
}

.archive-card__link:hover::after {
    transform: translateX(4px);
}
