/**
 * WCPC Sermon Manager — Shared Components
 *
 * Defines the design-system components used across multiple widgets:
 *   - .wcpc-pill (with variants)
 *   - .wcpc-card (BEM anatomy)
 *   - .wcpc-button (primary / ghost — matches Kit button)
 *
 * Every selector is scoped under `.wcpc-sermons` per §7 of DESIGN-SYSTEM.md.
 * Legacy class aliases (`.wcpc-meta-badge`, `.wcpc-sg-ps-link`, `.wcpc-sg-card`,
 * `.wcpc-sg-image`, etc.) are paired with the new BEM classes via selector
 * grouping so existing markup and any user CSS continue to match.
 *
 * Load order: design-tokens.css -> components.css -> frontend.css
 *
 * @package WCPC_Sermons
 * @since   1.38.0
 */

/* ============================================================
   Pill / Chip
   ============================================================ */

.wcpc-sermons .wcpc-pill,
.wcpc-sermons .wcpc-meta-badge,
.wcpc-sermons .wcpc-sg-ps-link {
    display: inline-flex;
    align-items: center;
    gap: var(--pl-space-1);
    font-family: var(--pl-font-accent);
    font-weight: 500;
    font-size: var(--pl-font-size-micro);
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: var(--pl-letter-spacing-accent);
    padding: 4px 10px;
    border: 1px solid transparent;
    border-radius: var(--pl-radius-pill);
    background: var(--pl-surface-section);
    color: var(--pl-text-strong);
    text-decoration: none;
    transition: background-color var(--pl-transition-fast),
                color var(--pl-transition-fast),
                border-color var(--pl-transition-fast);
}

.wcpc-sermons a.wcpc-pill,
.wcpc-sermons a.wcpc-sg-ps-link {
    cursor: pointer;
}

.wcpc-sermons a.wcpc-pill:hover,
.wcpc-sermons a.wcpc-sg-ps-link:hover {
    background: rgba(52, 101, 127, 0.12);
    color: var(--pl-color-primary);
    text-decoration: none;
}

.wcpc-sermons .wcpc-pill:focus-visible,
.wcpc-sermons .wcpc-sg-ps-link:focus-visible {
    outline: none;
    box-shadow: var(--pl-focus-ring);
}

/* Variants */

.wcpc-sermons .wcpc-pill--info,
.wcpc-sermons .wcpc-sg-ps-link {
    background: rgba(52, 101, 127, 0.10);
    color: var(--pl-color-primary);
}

.wcpc-sermons .wcpc-pill--success {
    background: rgba(75, 149, 96, 0.12);
    color: var(--pl-color-success);
}

.wcpc-sermons .wcpc-pill--warn {
    background: rgba(255, 181, 73, 0.18);
    color: var(--pl-color-warn-text);
}

.wcpc-sermons .wcpc-pill--error {
    background: rgba(239, 96, 121, 0.12);
    color: var(--pl-color-error-text);
}

.wcpc-sermons .wcpc-pill--muted,
.wcpc-sermons .wcpc-meta-badge {
    background: var(--pl-surface-section);
    color: var(--pl-text-strong);
}

/* Optional icon inside a pill */
.wcpc-sermons .wcpc-pill svg,
.wcpc-sermons .wcpc-pill i,
.wcpc-sermons .wcpc-sg-ps-link svg {
    flex-shrink: 0;
    width: 1em;
    height: 1em;
}

/* Preacher P.S. duration sub-label (legacy) */
.wcpc-sermons .wcpc-sg-ps-dur {
    opacity: 0.7;
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
}

/* ============================================================
   Card
   ============================================================ */

.wcpc-sermons .wcpc-card,
.wcpc-sermons .wcpc-sg-card {
    display: flex;
    flex-direction: column;
    background: var(--pl-surface-card);
    border: 1px solid var(--pl-border-hairline);
    border-radius: var(--pl-radius-md);
    overflow: hidden;
    transition: box-shadow var(--pl-transition-base),
                transform var(--pl-transition-base);
}

.wcpc-sermons .wcpc-card:hover,
.wcpc-sermons .wcpc-sg-card:hover {
    box-shadow: var(--pl-shadow-sm);
    transform: translateY(-2px);
}

.wcpc-sermons .wcpc-card:focus-within,
.wcpc-sermons .wcpc-sg-card:focus-within {
    box-shadow: var(--pl-focus-ring);
    outline: none;
}

/* Radius size buckets (mapped from Sermon_Card::$config['borderRadius'] integer) */
.wcpc-sermons .wcpc-card--radius-sm { border-radius: var(--pl-radius-sm); }
.wcpc-sermons .wcpc-card--radius-md { border-radius: var(--pl-radius-md); }
.wcpc-sermons .wcpc-card--radius-lg { border-radius: var(--pl-radius-lg); }

/* Media */
.wcpc-sermons .wcpc-card__media,
.wcpc-sermons .wcpc-sg-image {
    display: block;
    overflow: hidden;
    line-height: 0;
    background: var(--pl-surface-section);
    aspect-ratio: 16 / 9;
}

.wcpc-sermons .wcpc-card__media img,
.wcpc-sermons .wcpc-sg-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--pl-transition-slow);
}

.wcpc-sermons .wcpc-card:hover .wcpc-card__media img,
.wcpc-sermons .wcpc-sg-card:hover .wcpc-sg-image img {
    transform: scale(1.03);
}

/* Body */
.wcpc-sermons .wcpc-card__body,
.wcpc-sermons .wcpc-sg-content {
    padding: var(--pl-space-4);
    display: flex;
    flex-direction: column;
    gap: var(--pl-space-2);
    flex: 1;
}

/* Eyebrow */
.wcpc-sermons .wcpc-card__eyebrow {
    display: block;
    font-family: var(--pl-font-eyebrow);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: var(--pl-letter-spacing-accent);
    font-size: var(--pl-font-size-micro);
    color: var(--pl-text-strong);
    margin: 0;
}

/* Title */
.wcpc-sermons .wcpc-card__title,
.wcpc-sermons .wcpc-sg-title {
    font-family: var(--pl-font-display);
    font-weight: 700;
    font-size: var(--pl-font-size-h5);    /* 20px */
    line-height: 1.2;
    color: var(--pl-color-primary);
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.wcpc-sermons .wcpc-card__title a,
.wcpc-sermons .wcpc-sg-title a {
    color: inherit;
    text-decoration: none;
}

.wcpc-sermons .wcpc-card:hover .wcpc-card__title a,
.wcpc-sermons .wcpc-sg-card:hover .wcpc-sg-title a {
    text-decoration: underline;
}

/* Meta (icon+label rows) */
.wcpc-sermons .wcpc-card__meta,
.wcpc-sermons .wcpc-sg-meta {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: var(--pl-space-3);
    font-family: var(--pl-font-body);
    font-size: var(--pl-font-size-small);
    color: var(--pl-text-strong);
    line-height: 1.4;
}

.wcpc-sermons .wcpc-card__meta li {
    display: inline-flex;
    align-items: center;
    gap: var(--pl-space-1);
    min-width: 0;
}

.wcpc-sermons .wcpc-card__meta li i,
.wcpc-sermons .wcpc-card__meta li svg {
    flex-shrink: 0;
    opacity: 0.75;
}

.wcpc-sermons .wcpc-card__meta a,
.wcpc-sermons .wcpc-sg-meta a {
    color: inherit;
    text-decoration: none;
}

.wcpc-sermons .wcpc-card__meta a:hover,
.wcpc-sermons .wcpc-sg-meta a:hover {
    text-decoration: underline;
}

/* Legacy dot separator (only active on elements that still use the old
   inline span structure — safe to keep) */
.wcpc-sermons .wcpc-sg-sep {
    margin: 0 var(--pl-space-1);
    opacity: 0.4;
}

@media (max-width: 767px) {
    .wcpc-sermons .wcpc-card__meta {
        flex-direction: column;
        gap: var(--pl-space-1);
    }
}

/* Pills row */
.wcpc-sermons .wcpc-card__pills {
    display: flex;
    flex-wrap: wrap;
    gap: var(--pl-space-1);
    align-items: center;
}

/* Footer */
.wcpc-sermons .wcpc-card__footer {
    display: flex;
    flex-wrap: wrap;
    gap: var(--pl-space-2);
    align-items: center;
    margin-top: auto;   /* pin to bottom of card body */
    padding-top: var(--pl-space-2);
}

/* ============================================================
   Card Grid
   ============================================================ */

.wcpc-sermons .wcpc-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--pl-space-5);
}

.wcpc-sermons .wcpc-grid--wide {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (max-width: 1024px) {
    .wcpc-sermons .wcpc-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 767px) {
    .wcpc-sermons .wcpc-grid,
    .wcpc-sermons .wcpc-grid--wide { grid-template-columns: 1fr; }
}

/* ============================================================
   Button (Kit-matched)
   ============================================================ */

.wcpc-sermons .wcpc-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--pl-space-2);
    font-family: var(--pl-font-accent);
    font-weight: 500;
    font-size: var(--pl-font-size-body);
    line-height: 1.2;
    text-transform: uppercase;
    letter-spacing: var(--pl-letter-spacing-accent);
    padding: 10px 20px;
    border: 1px solid transparent;
    border-radius: var(--pl-radius-md);
    text-decoration: none;
    cursor: pointer;
    transition: background-color var(--pl-transition-fast),
                color var(--pl-transition-fast),
                border-color var(--pl-transition-fast);
}

.wcpc-sermons .wcpc-button--primary {
    background: var(--pl-color-primary);
    color: var(--pl-text-on-primary);
}

.wcpc-sermons .wcpc-button--primary:hover {
    background: var(--pl-color-primary-dark);
    color: var(--pl-text-on-primary);
}

.wcpc-sermons .wcpc-button--ghost {
    background: transparent;
    color: var(--pl-color-primary);
    border-color: var(--pl-color-primary);
}

.wcpc-sermons .wcpc-button--ghost:hover {
    background: var(--pl-color-primary);
    color: var(--pl-text-on-primary);
}

.wcpc-sermons .wcpc-button:focus-visible {
    outline: none;
    box-shadow: var(--pl-focus-ring);
}

.wcpc-sermons .wcpc-button[disabled],
.wcpc-sermons .wcpc-button.is-disabled {
    opacity: 0.5;
    cursor: not-allowed;
}
