.boa-schedule {
    --boa-bg: #f6f8fb;
    --boa-card: #ffffff;
    --boa-text: #121826;
    --boa-muted: #64748b;
    --boa-accent: #e11d48;
    --boa-accent-dark: #9f1239;
    --boa-line: #e2e8f0;
    max-width: 1100px;
    margin: 40px auto;
    padding: 28px;
    background: linear-gradient(135deg, #ffffff 0%, var(--boa-bg) 100%);
    border-radius: 28px;
    box-shadow: 0 24px 70px rgba(15, 23, 42, .08);
    color: var(--boa-text);
}

.boa-schedule * { box-sizing: border-box; }

.boa-schedule-header { text-align: center; margin-bottom: 26px; }
.boa-eyebrow { color: var(--boa-accent); text-transform: uppercase; letter-spacing: .12em; font-weight: 800; font-size: 12px; }
.boa-schedule-header h2 { margin: 8px 0 6px; font-size: clamp(32px, 5vw, 54px); line-height: 1; }
.boa-schedule-header p { margin: 0; color: var(--boa-muted); font-size: 17px; }

.boa-day-tabs { display: flex; gap: 10px; overflow-x: auto; padding: 8px 0 18px; margin-bottom: 8px; }
.boa-day-tab { flex: 0 0 auto; text-decoration: none; color: var(--boa-text); background: #fff; border: 1px solid var(--boa-line); border-radius: 999px; padding: 10px 16px; font-weight: 700; transition: .2s ease; }
.boa-day-tab:hover { color: #fff; background: var(--boa-accent); border-color: var(--boa-accent); transform: translateY(-1px); }

.boa-day-section { padding: 22px 0; border-top: 1px solid var(--boa-line); scroll-margin-top: 90px; }
.boa-day-section h3 { margin: 0 0 16px; font-size: 26px; }
.boa-program-list { display: grid; gap: 14px; }

.boa-program-card { display: grid; grid-template-columns: 130px 1fr; gap: 18px; background: var(--boa-card); border: 1px solid var(--boa-line); border-radius: 22px; padding: 18px; box-shadow: 0 12px 30px rgba(15, 23, 42, .05); transition: .2s ease; }
.boa-program-card:hover { transform: translateY(-2px); box-shadow: 0 18px 40px rgba(15, 23, 42, .09); }

.boa-time { border-right: 1px solid var(--boa-line); padding-right: 18px; display: flex; flex-direction: column; justify-content: center; }
.boa-time strong { font-size: 28px; line-height: 1; color: var(--boa-accent); }
.boa-time span { margin-top: 8px; color: var(--boa-muted); font-weight: 700; }

.boa-program-topline { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 8px; }
.boa-chip, .boa-live { display: inline-flex; align-items: center; border-radius: 999px; padding: 5px 10px; font-size: 12px; font-weight: 800; }
.boa-chip { background: #f1f5f9; color: #334155; }
.boa-live { background: #fee2e2; color: #b91c1c; }
.boa-live::before { content: ''; width: 7px; height: 7px; background: currentColor; border-radius: 50%; margin-right: 6px; }

.boa-program-content h4 { margin: 0; font-size: 23px; }
.boa-host { margin: 6px 0 0; font-weight: 700; color: var(--boa-accent-dark); }
.boa-description { margin: 10px 0 0; color: var(--boa-muted); line-height: 1.55; }
.boa-no-programs, .boa-empty { color: var(--boa-muted); font-style: italic; }

@media (max-width: 700px) {
    .boa-schedule { padding: 20px; border-radius: 20px; }
    .boa-program-card { grid-template-columns: 1fr; gap: 12px; }
    .boa-time { border-right: 0; border-bottom: 1px solid var(--boa-line); padding-right: 0; padding-bottom: 12px; flex-direction: row; justify-content: flex-start; align-items: baseline; gap: 10px; }
    .boa-time strong { font-size: 24px; }
    .boa-time span::before { content: 'tot '; }
}

/* v1.1.1 uitbreidingen */
.boa-day-tabs {
    position: sticky;
    top: var(--boa-sticky-offset, 112px);
    z-index: 5;
    background: rgba(246, 248, 251, .92);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-radius: 999px;
    padding: 10px;
    border: 1px solid rgba(226, 232, 240, .8);
}

body.admin-bar .boa-day-tabs { top: calc(var(--boa-sticky-offset, 112px) + 32px); }

.boa-day-tab.is-today {
    border-color: var(--boa-accent);
    color: var(--boa-accent);
    box-shadow: 0 8px 20px rgba(225, 29, 72, .12);
}

.boa-program-card.is-current {
    border-color: rgba(225, 29, 72, .42);
    background: linear-gradient(135deg, #fff 0%, #fff7f9 100%);
    box-shadow: 0 20px 48px rgba(225, 29, 72, .14);
    position: relative;
    overflow: hidden;
}

.boa-program-card.is-current::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 6px;
    background: var(--boa-accent);
}

.boa-now {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 5px 10px;
    font-size: 12px;
    font-weight: 900;
    background: var(--boa-accent);
    color: #fff;
}

.boa-now::before {
    content: '';
    width: 7px;
    height: 7px;
    background: currentColor;
    border-radius: 50%;
    margin-right: 6px;
    animation: boaPulse 1.2s infinite;
}

.boa-listen-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 14px;
    background: var(--boa-accent);
    color: #fff !important;
    text-decoration: none;
    font-weight: 900;
    border-radius: 999px;
    padding: 11px 18px;
    box-shadow: 0 12px 28px rgba(225, 29, 72, .22);
    transition: .2s ease;
}

.boa-listen-button:hover {
    background: var(--boa-accent-dark);
    transform: translateY(-1px);
}

@keyframes boaPulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: .55; transform: scale(.75); }
}

@media (max-width: 782px) {
    body.admin-bar .boa-day-tabs { top: calc(var(--boa-sticky-offset, 112px) + 46px); }
}
