/**
 * NeoEPG – Channel Page Template
 * template="channel-page"
 */

/* ── Root ─────────────────────────────────────────────────────────────────── */
.tvschedule-epg--channel-page {
    --cp-color: #1B4F72;
    --cp-radius: 12px;
    --cp-gap: 20px;
    font-family: var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
    color: #1a1a2e;
    background: #f5f7fa;
    border-radius: var(--cp-radius);
    overflow: hidden;
    box-shadow: 0 2px 16px rgba(0,0,0,.08);
}

/* Reserve layout space early to reduce visible layout shift while fonts/images hydrate. */
.tvschedule-epg--channel-page {
    contain: layout paint;
}


/* ── Hero ─────────────────────────────────────────────────────────────────── */
.tvschedule-epg__cp-hero {
    position: relative;
    background: linear-gradient(135deg, #0f1729 0%, #1a2444 100%);
    padding: 28px 28px 22px;
    overflow: hidden;
    min-height: 138px;
}

.tvschedule-epg__cp-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 80% 50%, color-mix(in srgb, var(--cp-color) 30%, transparent) 0%, transparent 65%);
    pointer-events: none;
}

.tvschedule-epg__cp-hero-inner {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.tvschedule-epg__cp-hero-brand {
    display: flex;
    align-items: center;
    gap: 16px;
}

.tvschedule-epg__cp-logo {
    width: 72px;
    height: 72px;
    object-fit: contain;
    border-radius: 10px;
    background: rgba(255,255,255,.08);
    padding: 6px;
    flex-shrink: 0;
}

.tvschedule-epg__cp-logo-placeholder {
    width: 72px;
    height: 72px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--cp-size-meta, 22px);
    font-family: var(--cp-heading-font, var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif));
    font-weight: 800;
    color: #fff;
    text-transform: uppercase;
    flex-shrink: 0;
}

.tvschedule-epg__cp-hero-info {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.tvschedule-epg__cp-channel-name {
    margin: 0;
    font-size: var(--cp-size-channel-name, 26px);
    font-family: var(--cp-heading-font, var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif));
    font-weight: 800;
    color: var(--cp-font-channel-name, #fff);
    line-height: 1.15;
    letter-spacing: -0.02em;
}

.tvschedule-epg__cp-hero-date {
    font-size: var(--cp-size-meta, 13px);
    font-family: var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
    color: rgba(255,255,255,.5);
    letter-spacing: .02em;
}

.tvschedule-epg__cp-hero-nav {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}

.tvschedule-epg__cp-nav-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: rgba(255,255,255,.1);
    color: rgba(255,255,255,.7);
    text-decoration: none;
    transition: background .15s, color .15s;
}
.tvschedule-epg__cp-nav-btn:hover {
    background: rgba(255,255,255,.2);
    color: #fff;
}

.tvschedule-epg__cp-today-btn,
.tvschedule-epg__cp-today-btn:visited {
    padding: 6px 14px;
    border-radius: 999px;
    background: rgba(255,255,255,.12);
    color: rgba(255,255,255,.8);
    font-size: var(--cp-size-meta, 12px);
    font-family: var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
    font-weight: 600;
    text-decoration: none;
    transition: background .15s, color .15s;
    letter-spacing: .04em;
}
.tvschedule-epg__cp-today-btn:hover,
.tvschedule-epg__cp-today-btn:focus-visible {
    background: var(--cp-color);
    color: #fff;
}

.tvschedule-epg__cp-hero-stripe {
    height: 4px;
    margin-top: 22px;
    border-radius: 2px 2px 0 0;
}

/* ── Week bar ─────────────────────────────────────────────────────────────── */
.tvschedule-epg__cp-weekbar {
    display: flex;
    min-height: 78px;
    align-items: stretch;   /* days fill full height of bar */
    gap: 0;                 /* no gap — flex:1 distributes space evenly */
    background: #fff;
    padding: 0;             /* remove side padding so days reach the edges */
    border-bottom: 1px solid #eee;
    width: 100%;
}

.tvschedule-epg__cp-weeknav {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;    /* never shrink nav arrows */
    width: 36px;
    min-width: 36px;
    height: auto;
    color: #666;
    text-decoration: none;
    border-radius: 6px;
    flex-shrink: 0;
    transition: background .15s, color .15s;
}
.tvschedule-epg__cp-weeknav:hover {
    background: #f0f0f0;
    color: #111;
}

.tvschedule-epg__cp-weekdays {
    display: flex;
    align-items: stretch;
    flex: 1;
    overflow-x: auto;
    scrollbar-width: none;
    /* Spread days evenly across the full bar width */
    justify-content: space-between;
}
.tvschedule-epg__cp-weekdays::-webkit-scrollbar { display: none; }

.tvschedule-epg__cp-weekday {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    /* Grow equally so all 7 days fill the full width */
    flex: 1 1 0;
    padding: 10px 4px;
    text-decoration: none;
    /* Use Elementor Kit text colour if available, else mid-gray */
    color: var(--cp-font-meta, #555);
    border-bottom: 3px solid transparent;
    white-space: nowrap;
    transition: color .15s, border-color .15s;
    flex-shrink: 0;
}
.tvschedule-epg__cp-weekday:hover {
    color: #111;
}
.tvschedule-epg__cp-weekday.is-today .tvschedule-epg__cp-weekday-num {
    font-weight: 700;
    color: var(--cp-color, #1B4F72);
}
.tvschedule-epg__cp-weekday.is-active {
    color: var(--cp-color, #1B4F72);
    border-bottom-color: var(--cp-color, #1B4F72);
}

.tvschedule-epg__cp-weekday-short {
    font-size: var(--cp-size-weekday, 11px);
    font-family: var(--cp-heading-font, var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif));
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: .06em;
    opacity: .65;
}
.tvschedule-epg__cp-weekday-num {
    font-size: calc(var(--cp-size-weekday, 11px) + 5px);
    font-family: var(--cp-heading-font, var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif));
    font-weight: 600;
    line-height: 1.2;
    margin-top: 2px;
}

/* ── Sections ─────────────────────────────────────────────────────────────── */
.tvschedule-epg__cp-section {
    min-height: 64px;
    padding: 20px;
}

.tvschedule-epg__cp-section-label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: var(--cp-size-section-label, 11px);
    font-family: var(--cp-heading-font, var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif));
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: #888;
    margin-bottom: 12px;
}

/* Live dot */
.tvschedule-epg__cp-live-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #e74c3c;
    box-shadow: 0 0 0 0 rgba(231, 76, 60, .4);
    animation: tvsmepg-cp-pulse 1.8s ease-out infinite;
}
@keyframes tvsmepg-cp-pulse {
    0%   { box-shadow: 0 0 0 0   rgba(231,76,60,.4); }
    70%  { box-shadow: 0 0 0 8px rgba(231,76,60,0); }
    100% { box-shadow: 0 0 0 0   rgba(231,76,60,0); }
}

/* ── On Air Now card ──────────────────────────────────────────────────────── */
.tvschedule-epg__cp-now-card {
    display: flex;
    width: 100%;
    text-align: left;
    background: #fff;
    border: none;
    border-radius: var(--cp-radius);
    overflow: hidden;
    cursor: pointer;
    box-shadow: 0 2px 12px rgba(0,0,0,.07);
    transition: box-shadow .2s, transform .15s;
    border-left: 5px solid var(--cp-color);
}
.tvschedule-epg__cp-now-card:hover {
    box-shadow: 0 6px 24px rgba(0,0,0,.12);
    transform: translateY(-1px);
}

.tvschedule-epg__cp-now-image {
    width: 180px;
    min-height: 140px;
    background-size: cover;
    background-position: center;
    flex-shrink: 0;
}

.tvschedule-epg__cp-now-body {
    padding: 16px 18px;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.tvschedule-epg__cp-now-meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}

.tvschedule-epg__cp-now-time {
    font-size: var(--cp-size-meta, 12px);
    font-family: var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
    font-weight: 600;
    color: var(--cp-font-meta, #888);
    letter-spacing: .02em;
}

.tvschedule-epg__cp-now-cat {
    font-size: 11px;
    font-weight: 600;
    color: var(--cp-color);
    background: color-mix(in srgb, var(--cp-color) 12%, transparent);
    padding: 2px 8px;
    border-radius: 999px;
}

/* ── Title isolation ─────────────────────────────────────────────────────────
   Uses three-part specificity chain to beat any theme/Elementor-kit rule.
   Falls back to Elementor Kit primary heading colour (--e-global-color-primary)
   before the hard-coded safe value. */
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-now-title,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-row-title,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-coming-title {
    /* Nuke every gradient-text technique themes use */
    background:             none !important;
    background-image:       none !important;
    -webkit-background-clip: border-box !important;
    background-clip:         border-box !important;
    /* Set text-fill-color first to currentColor so the fallback chain below works */
    -webkit-text-fill-color: currentColor !important;
    text-shadow:  none !important;
    opacity:      1    !important;
    filter:       none !important;
    /* Colour: widget override → Elementor Kit primary → safe dark */
    color: var(--cp-font-title, #111) !important;
}
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-now-title {
    margin:          0        !important;
    font-size:       var(--cp-size-title, 20px);
    font-family:     var(--cp-heading-font, var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif));
    font-weight:     800;
    line-height:     1.2;
    letter-spacing:  -0.01em;
}

.tvschedule-epg__cp-now-episode {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: var(--cp-size-meta, 13px);
    font-family: var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
    color: var(--cp-font-meta, #666);
}

.tvschedule-epg__cp-ep-pill {
    background: #f0f0f0;
    color: #444;
    font-size: var(--cp-size-section-label, 11px);
    font-family: var(--cp-heading-font, var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif));
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 999px;
    letter-spacing: .03em;
}

.tvschedule-epg__cp-now-desc {
    margin: 0;
    font-size: var(--cp-size-meta, 13px);
    font-family: var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
    color: var(--cp-font-desc, #555);
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.tvschedule-epg__cp-progress-wrap {
    margin-top: 4px;
    height: 5px;
    background: #eee;
    border-radius: 3px;
    overflow: hidden;
}

.tvschedule-epg__cp-progress-bar {
    height: 100%;
    border-radius: 3px;
    transition: width .3s ease;
}

.tvschedule-epg__cp-progress-label {
    font-size: var(--cp-size-meta, 11px);
    font-family: var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
    color: #999;
    letter-spacing: .02em;
}

/* ── Coming Up ────────────────────────────────────────────────────────────── */
.tvschedule-epg__cp-coming-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
}

.tvschedule-epg__cp-coming-card {
    background: #fff;
    border: none;
    border-radius: var(--cp-radius);
    padding: 14px 16px;
    text-align: left;
    cursor: pointer;
    box-shadow: 0 1px 6px rgba(0,0,0,.05);
    border-top: 3px solid var(--cp-color);
    transition: box-shadow .2s, transform .15s;
    display: flex;
    flex-direction: column;
    gap: 5px;
}
.tvschedule-epg__cp-coming-card:hover {
    box-shadow: 0 4px 16px rgba(0,0,0,.1);
    transform: translateY(-1px);
}

.tvschedule-epg__cp-coming-time {
    font-size: var(--cp-size-meta, 22px);
    font-family: var(--cp-heading-font, var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif));
    font-weight: 800;
    color: var(--cp-color);
    letter-spacing: -0.02em;
    line-height: 1;
}

.tvschedule-epg__cp-coming-title {
    font-size: var(--cp-size-title, 14px);
    font-family: var(--cp-heading-font, var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif));
    font-weight: 700;
    /* Colour set via high-specificity rule above; keep here as regular fallback */
    color: var(--cp-font-title, #111);
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.tvschedule-epg__cp-coming-cat {
    font-size: var(--cp-size-meta, 11px);
    font-family: var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
    color: #888;
    font-weight: 500;
}

.tvschedule-epg__cp-coming-badges {
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
    margin-top: 2px;
}

/* ── Full Schedule List ───────────────────────────────────────────────────── */
.tvschedule-epg__cp-schedule {
    display: flex;
    flex-direction: column;
    border-radius: var(--cp-radius);
    overflow: hidden;
    background: #fff;
    box-shadow: 0 1px 6px rgba(0,0,0,.05);
    padding-bottom: 0;
}
.tvschedule-epg__cp-schedule::after {
    content: none;
    display: none;
}

.tvschedule-epg__cp-row {
    display: flex;
    align-items: center;
    gap: 0;
    width: 100%;
    text-align: left;
    background: transparent;
    border: none;
    border-bottom: 1px solid #f0f0f0;
    padding: 13px 16px;
    cursor: pointer;
    transition: background .15s;
    position: relative;
}
.tvschedule-epg__cp-row:hover { background: #fafafa; }

.tvschedule-epg__cp-row.is-current {
    background: color-mix(in srgb, var(--cp-color) 6%, transparent);
}
.tvschedule-epg__cp-row.is-current::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background: var(--cp-color);
    border-radius: 0 2px 2px 0;
}
.tvschedule-epg__cp-row.is-past {
    opacity: .45;
}

/* Time column */
.tvschedule-epg__cp-row-time {
    width: 56px;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 3px;
}

.tvschedule-epg__cp-row-start {
    font-size: var(--cp-size-title, 14px);
    font-family: var(--cp-heading-font, var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif));
    font-weight: 700;
    color: var(--cp-font-meta, #333);
    letter-spacing: .02em;
    font-variant-numeric: tabular-nums;
}

.tvschedule-epg__cp-row-now-badge {
    font-size: 9px;
    font-weight: 800;
    color: #fff;
    padding: 1px 5px;
    border-radius: 3px;
    letter-spacing: .06em;
    text-transform: uppercase;
}

/* Body */
.tvschedule-epg__cp-row-body {
    flex: 1;
    min-width: 0;
    padding: 0 12px;
}

.tvschedule-epg__cp-row-title {
    font-size: var(--cp-size-title, 14px);
    font-family: var(--cp-heading-font, var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif));
    font-weight: 600;
    /* Colour set via high-specificity rule above; keep here as regular fallback */
    color: var(--cp-font-title, #111);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.3;
}
.is-current .tvschedule-epg__cp-row-title {
    font-weight: 700;
    color: var(--cp-color);
}

.tvschedule-epg__cp-row-episode {
    font-size: var(--cp-size-meta, 12px);
    font-family: var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
    color: #777;
    display: flex;
    gap: 6px;
    margin-top: 2px;
}

.tvschedule-epg__cp-row-meta {
    display: flex;
    gap: 10px;
    margin-top: 3px;
    font-size: var(--cp-size-meta, 12px);
    font-family: var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
    color: #999;
}

/* Right column */
.tvschedule-epg__cp-row-right {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
    margin-left: 8px;
}

.tvschedule-epg__cp-row-duration {
    font-size: var(--cp-size-meta, 11px);
    font-family: var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
    color: #bbb;
    font-weight: 500;
    white-space: nowrap;
}

.tvschedule-epg__cp-row-arrow {
    color: #ccc;
    flex-shrink: 0;
}
.tvschedule-epg__cp-row:hover .tvschedule-epg__cp-row-arrow {
    color: #888;
}

/* ── Empty State ─────────────────────────────────────────────────────────── */
.tvschedule-epg__cp-no-schedule {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    padding: 48px 24px;
    text-align: center;
}
.tvschedule-epg__cp-no-schedule-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
    background: #fff;
    border-radius: 16px;
    padding: 40px 48px;
    box-shadow: 0 2px 16px rgba(0,0,0,.07);
    max-width: 360px;
    width: 100%;
}
.tvschedule-epg__cp-no-schedule-icon {
    color: var(--cp-color, #1B4F72);
    opacity: .55;
    line-height: 1;
}
.tvschedule-epg__cp-no-schedule-text {
    font-size: var(--cp-size-meta, 15px);
    font-family: var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
    color: #555;
    margin: 0;
    font-weight: 500;
    line-height: 1.4;
}
.tvschedule-epg__cp-no-schedule-link {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: var(--cp-size-meta, 13px);
    font-family: var(--cp-body-font, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
    color: #fff;
    background: var(--cp-color, #1B4F72);
    text-decoration: none;
    font-weight: 600;
    padding: 8px 18px;
    border-radius: 999px;
    transition: opacity .15s;
    margin-top: 2px;
}
.tvschedule-epg__cp-no-schedule-link:hover { opacity: .85; text-decoration: none; }

/* Dark skin empty state */
.skin-dark .tvschedule-epg__cp-no-schedule-inner {
    background: #1f2937;
    box-shadow: 0 2px 16px rgba(0,0,0,.3);
}
.skin-dark .tvschedule-epg__cp-no-schedule-text { color: #9ca3af; }

/* ── Empty (no channel) ──────────────────────────────────────────────────── */
.tvschedule-epg__cp-empty {
    padding: 40px 24px;
    text-align: center;
    color: #999;
    font-size: 14px;
}

/* ── Dark skin ───────────────────────────────────────────────────────────── */
.skin-dark.tvschedule-epg--channel-page {
    background: #111827;
    color: #e5e7eb;
}
.skin-dark .tvschedule-epg__cp-weekbar {
    background: #1f2937;
    border-color: #374151;
}
.skin-dark .tvschedule-epg__cp-weekday { color: var(--cp-weekday-color, #9ca3af); }
.skin-dark .tvschedule-epg__cp-weekday:hover { color: #e5e7eb; }
.skin-dark .tvschedule-epg__cp-weekday.is-active { color: var(--cp-weekday-active-color, var(--cp-color)); }
.skin-dark .tvschedule-epg__cp-now-card,
.skin-dark .tvschedule-epg__cp-coming-card,
.skin-dark .tvschedule-epg__cp-schedule {
    background: #1f2937;
    box-shadow: 0 2px 12px rgba(0,0,0,.3);
}
/* Dark skin: override CSS variable fallbacks for all text elements.
   skin-dark is on the SAME element as tvschedule-epg--channel-page (no space). */
.skin-dark.tvschedule-epg--channel-page {
    /* Override fallback values in dark mode so var(--cp-font-X, fallback) picks up dark defaults */
    --cp-font-title: #f3f4f6;
    --cp-font-desc: #d1d5db;
    --cp-font-meta: #9ca3af;
    --cp-font-channel-name: #fff;
}
.skin-dark .tvschedule-epg__cp-now-title,
.skin-dark .tvschedule-epg__cp-row-title,
.skin-dark .tvschedule-epg__cp-coming-title { color: var(--cp-font-title, #f3f4f6) !important; -webkit-text-fill-color: var(--cp-font-title, #f3f4f6) !important; }
/* Time & meta */
.skin-dark .tvschedule-epg__cp-now-time { color: var(--cp-font-meta, #9ca3af); }
.skin-dark .tvschedule-epg__cp-now-cat {
    color: var(--cp-color);
    background: color-mix(in srgb, var(--cp-color) 18%, #1f2937);
}
/* Description & episode info */
.skin-dark .tvschedule-epg__cp-now-desc { color: var(--cp-font-desc, #d1d5db); }
.skin-dark .tvschedule-epg__cp-now-episode { color: var(--cp-font-meta, #9ca3af); }
/* Progress */
.skin-dark .tvschedule-epg__cp-progress-label { color: #6b7280; }
/* Coming Up card */
.skin-dark .tvschedule-epg__cp-coming-time { color: var(--cp-font-meta, #9ca3af); }
/* Full schedule rows */
.skin-dark .tvschedule-epg__cp-row { border-color: #374151; }
.skin-dark .tvschedule-epg__cp-row:hover { background: #263040; }
.skin-dark .tvschedule-epg__cp-row.is-current { background: color-mix(in srgb, var(--cp-color) 15%, #1f2937); }
.skin-dark .tvschedule-epg__cp-row-start { color: var(--cp-font-meta, #d1d5db); }
.skin-dark .tvschedule-epg__cp-row-duration { color: #6b7280; }
.skin-dark .tvschedule-epg__cp-progress-wrap { background: #374151; }
.skin-dark .tvschedule-epg__cp-ep-pill { background: #374151; color: #9ca3af; }
.skin-dark .tvschedule-epg__cp-section-label,
.skin-dark .tvschedule-epg__cp-hero-date { color: #6b7280; }

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 640px) {
    .tvschedule-epg--channel-page {
        --cp-size-meta: var(--cp-size-meta-mobile, var(--cp-size-meta, 13px));
        --cp-size-section-label: var(--cp-size-section-label-mobile, var(--cp-size-section-label, 11px));
        --cp-size-weekday: var(--cp-size-weekday-mobile, var(--cp-size-weekday, 11px));
    }
    .tvschedule-epg__cp-hero {
        padding: 20px 16px 16px;
    }
    .tvschedule-epg__cp-logo,
    .tvschedule-epg__cp-logo-placeholder {
        width: 52px;
        height: 52px;
    }
    .tvschedule-epg__cp-channel-name {
        font-size: var(--cp-size-channel-name-mobile, var(--cp-size-channel-name, 20px));
    }
    .tvschedule-epg__cp-now-image {
        display: none;
    }
    .tvschedule-epg__cp-now-title {
        font-size: var(--cp-size-title-mobile, var(--cp-size-title, 17px));
    }
    .tvschedule-epg__cp-coming-grid {
        grid-template-columns: 1fr;
    }
    .tvschedule-epg__cp-section {
        padding: 14px 12px;
    }
    .tvschedule-epg__cp-row {
        padding: 11px 12px;
    }
    .tvschedule-epg__cp-row-time {
        width: 46px;
    }
}

/* ── Theme isolation: force-reset <a> styles on weekday links ──────────────
   Some themes apply global border, border-radius, background, width etc.
   to every <a> element, which turns weekday buttons into circles/blobs.
   These !important rules ensure our styles always win regardless of theme. */
.tvschedule-epg--channel-page .tvschedule-epg__cp-weekday {
    display:          flex      !important;
    flex-direction:   column    !important;
    align-items:      center    !important;
    justify-content:  center    !important;
    flex:             1 1 0     !important;   /* equal width — fills full bar */
    border:           none      !important;
    border-bottom:    3px solid transparent !important;
    border-radius:    0         !important;
    background:       transparent !important;
    background-color: transparent !important;
    box-shadow:       none      !important;
    width:            auto      !important;
    height:           auto      !important;
    min-width:        0         !important;
    min-height:       0         !important;
    padding:          10px 4px  !important;
    margin:           0         !important;
    outline:          none      !important;
    /* Use Elementor Kit text colour so the days are always readable */
    color: var(--cp-weekday-color, #555) !important;
    /* Reset gradient-text tricks themes may apply to <a> */
    -webkit-text-fill-color: currentColor !important;
    -webkit-background-clip: border-box !important;
    background-clip: border-box !important;
}
.tvschedule-epg--channel-page .tvschedule-epg__cp-weekday.is-active {
    border-bottom-color: var(--cp-color, #1B4F72) !important;
    color: var(--cp-weekday-active-color, var(--cp-color, #1B4F72)) !important;
    -webkit-text-fill-color: var(--cp-weekday-active-color, var(--cp-color, #1B4F72)) !important;
    background: transparent !important;
    background-color: transparent !important;
}
.tvschedule-epg--channel-page .tvschedule-epg__cp-weekday:hover {
    background:       transparent !important;
    background-color: transparent !important;
    color: var(--cp-weekday-color, #555) !important;
    -webkit-text-fill-color: var(--cp-weekday-color, #555) !important;
}
.tvschedule-epg--channel-page .tvschedule-epg__cp-weekday-short,
.tvschedule-epg--channel-page .tvschedule-epg__cp-weekday-num {
    display:          block      !important;
    background:       none       !important;
    background-color: transparent !important;
    border:           none       !important;
    border-radius:    0          !important;
    padding:          0          !important;
    margin:           0          !important;
    box-shadow:       none       !important;
    width:            auto       !important;
    height:           auto       !important;
    line-height:      inherit    !important;
    color:            inherit    !important;
    -webkit-text-fill-color: inherit !important;
}

.tvschedule-epg__modal-person{display:flex;align-items:center;gap:12px;margin:10px 0 8px;}
.tvschedule-epg__modal-person-image{width:52px;height:52px;border-radius:999px;object-fit:cover;flex:0 0 52px;}
.tvschedule-epg__modal-person-label,.tvschedule-epg__modal-people{font-size:12px;color:var(--tvs-muted,#9da7c3);}
.tvschedule-epg__modal-person-name{font-size:14px;font-weight:600;}
.tvschedule-epg__modal-people{margin:6px 0 0;}


/* v1.0.2 hard theme isolation for channel page */
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-today-btn,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-today-btn:link,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-today-btn:visited,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-today-btn:hover,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-today-btn:active,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-day,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-day:link,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-day:visited,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-day:hover,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-day:active,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-nav,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-nav:link,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-nav:visited,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-nav:hover,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-nav:active,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-row,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-row:hover,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-row:active,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-row:focus,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-row:focus-visible{
  text-decoration:none !important;
  background-image:none !important;
}
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-row:active,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-row.is-active-click,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-row.is-modal-triggered{
  background:inherit !important;
  filter:none !important;
  -webkit-tap-highlight-color:transparent;
}


/* v1.0.3 keep plugin-owned row/button states regardless of theme */
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-today-btn,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-today-btn:link,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-today-btn:visited,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-today-btn:hover,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-today-btn:active,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-nav-btn,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-nav-btn:link,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-nav-btn:visited,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-nav-btn:hover,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-nav-btn:active,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-weeknav,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-weeknav:link,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-weeknav:visited,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-weeknav:hover,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-weeknav:active,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-weekday,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-weekday:link,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-weekday:visited,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-weekday:hover,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-weekday:active {
  text-decoration:none !important;
  background-image:none !important;
}
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-today-btn,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-today-btn:link,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-today-btn:visited,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-today-btn:hover,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-today-btn:active {
  color: rgba(255,255,255,.8) !important;
}
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-today-btn:hover,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-today-btn:focus-visible {
  color:#fff !important;
}
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-row,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-row:hover,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-row:active,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-row:focus,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-row:focus-visible,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-row.is-active-click,
.tvschedule-epg.tvschedule-epg--channel-page .tvschedule-epg__cp-row.is-modal-triggered{
  filter:none !important;
  text-decoration:none !important;
  background-image:none !important;
  box-shadow:none !important;
}
.skin-dark.tvschedule-epg--channel-page .tvschedule-epg__cp-row:active,
.skin-dark.tvschedule-epg--channel-page .tvschedule-epg__cp-row.is-active-click,
.skin-dark.tvschedule-epg--channel-page .tvschedule-epg__cp-row.is-modal-triggered{
  background:#1f2937 !important;
}
.skin-dark.tvschedule-epg--channel-page .tvschedule-epg__cp-row.is-current:active,
.skin-dark.tvschedule-epg--channel-page .tvschedule-epg__cp-row.is-current.is-active-click,
.skin-dark.tvschedule-epg--channel-page .tvschedule-epg__cp-row.is-current.is-modal-triggered{
  background:color-mix(in srgb, var(--cp-color) 15%, #1f2937) !important;
}
