/* AGTV Programs - Modern Cards + Single Templates */
:root{
  --agtvp-radius: 18px;
  --agtvp-shadow: 0 12px 30px rgba(0,0,0,.10);
  --agtvp-shadow-hover: 0 18px 45px rgba(0,0,0,.14);
  --agtvp-border: rgba(0,0,0,.08);
}

.agtvp-grid{
  display:grid;
  gap: var(--agtvp-gap, 18px);
  margin: var(--agtvp-section-margin, 0) 0;
  align-items:stretch;
}

.agtvp-cols-1{ grid-template-columns: repeat(1, minmax(0, 1fr)); }
.agtvp-cols-2{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
.agtvp-cols-3{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
.agtvp-cols-4{ grid-template-columns: repeat(4, minmax(0, 1fr)); }
.agtvp-cols-5{ grid-template-columns: repeat(5, minmax(0, 1fr)); }
.agtvp-cols-6{ grid-template-columns: repeat(6, minmax(0, 1fr)); }

@media (max-width: 1100px){
  .agtvp-cols-4,.agtvp-cols-5,.agtvp-cols-6{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 800px){
  .agtvp-cols-3,.agtvp-cols-4,.agtvp-cols-5,.agtvp-cols-6{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 520px){
  .agtvp-grid{ gap:14px; }
  .agtvp-cols-2,.agtvp-cols-3,.agtvp-cols-4,.agtvp-cols-5,.agtvp-cols-6{ grid-template-columns: repeat(1, minmax(0, 1fr)); }
}

.agtvp-card{
  border:1px solid var(--agtvp-border);
  border-radius: var(--agtvp-radius);
  overflow:hidden;
  background:#fff;
  box-shadow: var(--agtvp-shadow);
  display:flex;
  flex-direction:column;
  min-height: 100%;
  transition: transform .18s ease, box-shadow .18s ease;
}
.agtvp-card:hover{
  transform: translateY(-3px);
  box-shadow: var(--agtvp-shadow-hover);
}

.agtvp-card-thumb{
  position:relative;
  display:block;
  aspect-ratio: 16 / 9;
  overflow:hidden;
}
.agtvp-card-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform: scale(1.02);
  transition: transform .25s ease;
}
.agtvp-card:hover .agtvp-card-thumb img{
  transform: scale(1.06);
}

.agtvp-badge-live{
  position:absolute;
  top:12px;
  left:12px;
  padding:6px 10px;
  border-radius: 999px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.08em;
  background:#1db954;
  color: var(--agtvp-hero-text, #fff);
  box-shadow: 0 10px 20px rgba(0,0,0,.18);
  animation: agtvpPulse 1.2s infinite;
}
.agtvp-badge-live-lg{
  position:static;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 12px;
  font-size:12px;
  margin-bottom:10px;
}
@keyframes agtvpPulse{
  0%{ transform: scale(1); opacity: 1; }
  50%{ transform: scale(1.05); opacity: .88; }
  100%{ transform: scale(1); opacity: 1; }
}

.agtvp-card-body{
  padding: var(--agtvp-card-pad, 14px 16px 16px 16px);
  display:flex;
  flex-direction:column;
  gap:8px;
  flex:1;
}

.agtvp-card-title{
  margin:0;
  font-size:16px;
  line-height:1.25;
}

.agtvp-card-meta{
  font-size:12px;
  opacity:.75;
}

.agtvp-card-excerpt{
  margin:0;
  font-size:13px;
  line-height:1.45;
  opacity:.9;
  flex:1;
}

.agtvp-card-link{
  font-size:13px;
  font-weight:700;
  text-decoration:none;
  display:inline-flex;
  gap:8px;
  align-items:center;
}
.agtvp-card-link:hover{ text-decoration:underline; }

.agtvp-empty{
  padding:18px;
  border:1px dashed var(--agtvp-border);
  border-radius: var(--agtvp-radius);
  background: rgba(0,0,0,.02);
}

/* Programs page filters */
.agtvp-programs-page{ margin: 10px 0 20px; }
.agtvp-filters{
  display:grid;
  grid-template-columns: 220px 220px 1fr;
  gap:12px;
  margin-bottom:16px;
}
@media (max-width: 800px){
  .agtvp-filters{ grid-template-columns: 1fr; }
}
.agtvp-filter label{
  display:block;
  font-size:12px;
  font-weight:700;
  margin:0 0 6px;
  opacity:.85;
}
.agtvp-filter select,
.agtvp-filter input{
  width:100%;
  padding:10px 12px;
  border-radius: 12px;
  border:1px solid var(--agtvp-border);
  background:#fff;
}

.agtvp-pager{
  display:flex;
  justify-content:center;
  margin-top:16px;
}
.agtvp-btn{
  padding:10px 14px;
  border-radius: 999px;
  border:1px solid var(--agtvp-border);
  background:#fff;
  cursor:pointer;
  font-weight:700;
}
.agtvp-btn:disabled{
  opacity:.5;
  cursor:not-allowed;
}

/* Single templates */
.agtvp-single{ width:100%; }
.agtvp-hero{
  position:relative;
  min-height: 320px;
  background-size:cover;
  background-position:center;
  border-radius: 0;
  overflow:hidden;
  margin: 0;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  color: var(--agtvp-hero-text, #fff);
}

.agtvp-hero--text-light{ --agtvp-hero-text:#fff; }
.agtvp-hero--text-dark{ --agtvp-hero-text:#111; }

.agtvp-hero--overlay-none{ --agtvp-ov-top:0; --agtvp-ov-mid:0; --agtvp-ov-bot:0; }
.agtvp-hero--overlay-light{ --agtvp-ov-top:.05; --agtvp-ov-mid:.25; --agtvp-ov-bot:.35; }
.agtvp-hero--overlay-medium{ --agtvp-ov-top:.10; --agtvp-ov-mid:.55; --agtvp-ov-bot:.70; }
.agtvp-hero--overlay-strong{ --agtvp-ov-top:.18; --agtvp-ov-mid:.68; --agtvp-ov-bot:.86; }

.agtvp-hero-overlay{
  position:absolute;
  inset:0;
  background: linear-gradient(180deg,
    rgba(0,0,0,var(--agtvp-ov-top,.10)) 0%,
    rgba(0,0,0,var(--agtvp-ov-mid,.55)) 70%,
    rgba(0,0,0,var(--agtvp-ov-bot,.70)) 100%);
}
.agtvp-hero-inner{
  position:relative;
  padding: 34px 22px;
  max-width: 1100px;
  margin: 0 auto;
  color: var(--agtvp-hero-text, #fff);
}
.agtvp-hero .agtvp-hero-title{
  margin:0;
  font-size: clamp(26px, 3vw, 44px);
  line-height:1.05;
  color: var(--agtvp-hero-title-color, var(--agtvp-hero-text, #fff));
}
.agtvp-hero .agtvp-hero-meta{
  margin-top:10px;
  font-size:13px;
  opacity:.92;
  color: var(--agtvp-hero-text, #fff);
}
.agtvp-single-main{
  max-width: 1100px;
  margin: 0 auto;
  padding: 18px 12px 40px;
}

.agtvp-single-main--spaced{
  padding-top: 44px;
}
.agtvp-section--subtle{
  background: rgba(0,0,0,.03);
  border: none;
  box-shadow: none;
  border-radius: 12px;
  padding: 28px 22px;
}
.agtvp-section{
  margin-top: 18px;
  padding: 18px;
  border-radius: 18px;
  background:#fff;
  border:1px solid var(--agtvp-border);
  box-shadow: var(--agtvp-shadow);
}
.agtvp-section-title{
  margin:0 0 12px;
  font-size:16px;
}
.agtvp-video iframe{
  width:100%;
  aspect-ratio: 16/9;
  border-radius: 14px;
}
.agtvp-content{
  font-size: 15px;
  line-height: 1.7;
}
.agtvp-note{
  padding: 12px 14px;
  border-radius: 14px;
  background: rgba(0,0,0,.04);
  border: 1px dashed var(--agtvp-border);
}
