/* ═══════════════════════════════════════════════════
   PROGRAM — Event schedule / lineup
   ═══════════════════════════════════════════════════ */

.program-list {
    padding-inline: var(--space-md);
}

.program-item {
    display: grid;
    grid-template-columns: 60px 1fr;
    gap: var(--space-sm);
    padding: var(--space-sm) 0;
    border-block-end: 1px dashed rgba(0, 0, 0, 0.15);
    align-items: start;

    animation: programSlide linear both;
    animation-timeline: view();
    animation-range: entry 0% entry 25%;
}

@keyframes programSlide {
    from {
        opacity: 0;
        transform: translateX(20px);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

.program-item:last-child {
    border-block-end: none;
}

.program-item__time {
    font-family: var(--font-sans);
    font-size: 1rem;
    font-weight: 700;
    color: var(--accent-red);
    white-space: nowrap;
}

.program-item__title {
    font-family: var(--font-serif);
    font-size: 1rem;
    font-weight: 700;
    margin-block-end: 3px;
}

.program-item__desc {
    font-size: 0.8rem;
    line-height: 1.4;
    color: var(--text-muted);
}

/* ─── Info Box ─── */
.info-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-sm);
    padding-inline: var(--space-md);
}

.info-box {
    background: var(--white);
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: var(--border-radius-sm);
    padding: var(--space-sm);
    text-align: center;

    animation: cardSlideUp linear both;
    animation-timeline: view();
    animation-range: entry 0% entry 30%;
}

.info-box__icon {
    font-size: 1.5rem;
    margin-block-end: 6px;
}

.info-box__label {
    font-family: var(--font-sans);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--text-muted);
    margin-block-end: 4px;
}

.info-box__value {
    font-family: var(--font-serif);
    font-size: 1rem;
    font-weight: 700;
}