/* =============================================================

   TRUST TV - FRONT PAGE LAYOUT CSS

   Matches screenshot layout exactly

   ============================================================= */



/* ---- SHARED ---- */

.fp-view-all {

  font-size: 0.75rem;

  font-weight: 600;

  color: #888;

  text-transform: uppercase;

  letter-spacing: 0.05em;

  white-space: nowrap;

  transition: color 0.2s;

}

.fp-view-all:hover { color: #e63946; }



.fp-section-title {

  font-size: 0.82rem;

  font-weight: 800;

  text-transform: uppercase;

  letter-spacing: 0.1em;

  color: #fff;

  margin: 0;

}

.fp-section-title-plain {

  font-size: 0.82rem;

  font-weight: 800;

  text-transform: uppercase;

  letter-spacing: 0.1em;

  color: #fff;

  margin: 0;

  display: flex;

  align-items: center;

  gap: 0.4rem;

}

.fp-section-title-plain::before {

  content: '';

  display: inline-block;

  width: 3px;

  height: 16px;

  background: #e63946;

  border-radius: 2px;

  flex-shrink: 0;

}

.fp-trend-tag {

  font-size: 0.7rem;

  color: #e63946;

  font-weight: 700;

}

.fp-col-header {

  display: flex;

  align-items: center;

  justify-content: space-between;

  gap: 0.75rem;

  margin-bottom: 1rem;

  padding-bottom: 0.6rem;

  border-bottom: 2px solid #e63946;

}



/* ---- ROW 1: HERO + POLITICS ---- */

.fp-hero-politics-row {

  background: #0a0a0a;

  padding: 0;

}

.fp-hero-politics-grid {

  display: grid;

  grid-template-columns: 1fr 380px;

  gap: 0;

  min-height: 420px;

}



/* Hero */

.fp-hero-col {

  position: relative;

}

.fp-hero-bg {

  position: relative;

  height: 100%;

  min-height: 420px;

  background: linear-gradient(135deg, #0a0a14 0%, #1a0a0a 60%, #0a0a0a 100%);

  background-size: cover;

  background-position: center;

  display: flex;

  align-items: center;

  justify-content: center;

}

.fp-hero-overlay {

  position: absolute;

  inset: 0;

  background: rgba(0,0,0,0.25);

}

.fp-hero-content {

  position: relative;

  z-index: 1;

  padding: 2.5rem 2rem;

  display: flex;

  flex-direction: column;

  align-items: center;

  justify-content: flex-end;

  height: 100%;

  width: 100%;

  padding-bottom: 2rem;

}

.fp-hero-badge {

  display: inline-flex;

  align-items: center;

  gap: 0.4rem;

  background: #e63946;

  color: #fff;

  font-size: 0.7rem;

  font-weight: 800;

  letter-spacing: 0.12em;

  padding: 0.25rem 0.6rem;

  border-radius: 3px;

  margin-bottom: 1rem;

  text-transform: uppercase;

}

.fp-hero-title {

  font-size: clamp(1.6rem, 3vw, 2.6rem);

  font-weight: 900;

  color: #fff;

  line-height: 1.15;

  margin-bottom: 0.75rem;

  text-shadow: 0 2px 12px rgba(0,0,0,0.6);

}

.fp-hero-subtitle {

  font-size: 0.95rem;

  color: rgba(255,255,255,0.8);

  margin-bottom: 1.5rem;

  line-height: 1.5;

}

.fp-hero-btn {

  display: inline-flex;

  align-items: center;

  gap: 0.5rem;

  background: #e63946;

  color: #fff;

  font-size: 0.9rem;

  font-weight: 700;

  padding: 0.75rem 1.5rem;

  border-radius: 4px;

  text-decoration: none;

  transition: background 0.2s, transform 0.2s;

  box-shadow: 0 4px 16px rgba(230,57,70,0.4);

}

.fp-hero-btn:hover {

  background: #cc0000;

  color: #fff;

  transform: translateY(-2px);

}

.fp-hero-note {

  font-size: 0.75rem;

  color: rgba(255,255,255,0.5);

  margin-top: 0.75rem;

}



/* Politics sidebar */

.fp-politics-col {

  background: #111;

  border-left: 1px solid #1e1e1e;

  display: flex;

  flex-direction: column;

}

.fp-politics-header {

  display: flex;

  align-items: center;

  justify-content: space-between;

  padding: 0.85rem 1rem;

  border-bottom: 1px solid #1e1e1e;

  background: #0d0d0d;

}

.fp-section-title-group {

  display: flex;

  align-items: center;

  gap: 0.5rem;

}

.fp-section-icon { color: #e63946; font-size: 0.9rem; }

.fp-politics-list {

  list-style: none;

  margin: 0;

  padding: 0;

  flex: 1;

}

.fp-politics-item {

  display: flex;

  align-items: flex-start;

  gap: 0.6rem;

  padding: 0.75rem 1rem;

  border-bottom: 1px solid #1a1a1a;

  transition: background 0.2s;

}

.fp-politics-item:hover { background: #161616; }

.fp-pol-num {

  font-size: 1.1rem;

  font-weight: 800;

  color: #333;

  min-width: 20px;

  flex-shrink: 0;

  line-height: 1;

  padding-top: 2px;

}

.fp-pol-thumb {

  position: relative;

  flex-shrink: 0;

  width: 80px;

  height: 56px;

  overflow: hidden;

  border-radius: 3px;

  display: block;

}

.fp-pol-thumb img {

  width: 100%;

  height: 100%;

  object-fit: cover;

}

.fp-pol-dur {

  position: absolute;

  bottom: 3px;

  right: 3px;

  background: rgba(0,0,0,0.8);

  color: #fff;

  font-size: 0.6rem;

  font-weight: 700;

  padding: 1px 4px;

  border-radius: 2px;

}

.fp-pol-content { flex: 1; min-width: 0; }

.fp-pol-title {

  font-size: 0.8rem;

  font-weight: 700;

  line-height: 1.35;

  margin-bottom: 0.3rem;

}

.fp-pol-title a { color: #ddd; transition: color 0.2s; }

.fp-pol-title a:hover { color: #e63946; }

.fp-pol-date { font-size: 0.68rem; color: #666; }



/* ---- ROW 3: SHOWS ---- */

.fp-shows-section {

  background: #0d0d0d;

  padding: 1.25rem 0;

  border-bottom: 1px solid #1a1a1a;

}

.fp-shows-header {

  display: flex;

  align-items: center;

  justify-content: space-between;

  margin-bottom: 0.75rem;

}

.fp-shows-header .fp-section-title-plain {

  color: #fff;

  font-size: 0.82rem;

  letter-spacing: 0.04em;

}

.fp-shows-header .fp-view-all {

  color: #e63946;

  font-size: 0.75rem;

  font-weight: 900;

}

.fp-shows-grid {
  display: flex;
  gap: 0.875rem;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
  padding-bottom: 0.5rem;
}
.fp-shows-grid::-webkit-scrollbar { height: 6px; }
.fp-shows-grid::-webkit-scrollbar-track { background: #1a1a1a; border-radius: 3px; }
.fp-shows-grid::-webkit-scrollbar-thumb { background: #444; border-radius: 3px; }

.fp-show-card {
  flex: 0 0 auto;
  scroll-snap-align: start;
  min-width: 175px;

  position: relative;

  min-height: 104px;

  border-radius: 8px;

  overflow: hidden;

  color: #fff;

  display: flex;

  align-items: center;

  justify-content: center;

  text-align: center;

  padding: 1rem;

  box-shadow: 0 16px 40px rgba(0,0,0,0.12);

  transition: transform 0.2s, box-shadow 0.2s;

}

.fp-show-card:hover {

  transform: translateY(-3px);

  box-shadow: 0 20px 48px rgba(0,0,0,0.18);

}

.fp-show-card::before {

  content: "";

  position: absolute;

  inset: 0;

  background: linear-gradient(135deg, #061224, #1d2e4d);

}

.fp-show-card.red::before { background: linear-gradient(135deg, #191b2a, #9b0a12); }

.fp-show-card.orange::before { background: linear-gradient(135deg, #2c1705, #f06a11); }

.fp-show-card.blue::before { background: linear-gradient(135deg, #071524, #0f59b7); }

.fp-show-card.purple::before { background: linear-gradient(135deg, #19142c, #5d33b6); }

.fp-show-card.navy::before { background: linear-gradient(135deg, #07101d, #111d44); }
.fp-show-card.teal::before { background: linear-gradient(135deg, #022b35, #0b7a8f); }

.fp-show-bg-img {

  position: absolute;

  inset: 0;

}

.fp-show-bg-img img {

  width: 100%;

  height: 100%;

  object-fit: cover;

  opacity: 0.4;

}

.fp-show-overlay {

  position: absolute;

  inset: 0;

  background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.3) 100%);

}

.fp-show-inner {

  position: relative;

  z-index: 1;

  display: flex;

  flex-direction: column;

  align-items: center;

  text-decoration: none;

}

.fp-show-label {

  display: block;

  font-size: 11px;

  opacity: 0.82;

  text-transform: uppercase;

  font-weight: 800;

  color: rgba(255,255,255,0.82);

  margin-bottom: 0.25rem;

}

.fp-show-title {

  display: block;

  margin-top: 4px;

  font-size: clamp(1rem, 2vw, 1.45rem);

  line-height: 1;

  text-transform: uppercase;

  letter-spacing: -0.04em;

  color: #fff;

  font-weight: 900;

}

.fp-show-play {

  position: absolute;

  right: 10px;

  bottom: 10px;

  width: 26px;

  height: 26px;

  border-radius: 50%;

  background: rgba(255,255,255,0.92);

  color: #e63946;

  display: grid;

  place-items: center;

  font-size: 11px;

  font-weight: 950;

  z-index: 1;

}



/* ---- ROW 4: FEATURED + UPDATES + SIDEBAR ---- */

.fp-mid-section {

  padding: 1.5rem 0;

  background: #0a0a0a;

  border-bottom: 1px solid #1a1a1a;

}

.fp-mid-grid {

  display: grid;

  grid-template-columns: 1fr 1fr 300px;

  gap: 1.5rem;

  align-items: start;

}



/* Featured article */

.fp-featured-article {

  background: #111;

  border-radius: 6px;

  overflow: hidden;

  border: 1px solid #1e1e1e;

}

.fp-feat-img-link {

  display: block;

  position: relative;

  aspect-ratio: 16/9;

  overflow: hidden;

}

.fp-feat-img-link img {

  width: 100%;

  height: 100%;

  object-fit: cover;

  transition: transform 0.4s;

}

.fp-featured-article:hover .fp-feat-img-link img { transform: scale(1.04); }

.fp-feat-play {

  position: absolute;

  bottom: 0.6rem;

  left: 0.6rem;

  width: 36px;

  height: 36px;

  background: rgba(230,57,70,0.9);

  border-radius: 50%;

  display: flex;

  align-items: center;

  justify-content: center;

  color: #fff;

  font-size: 0.8rem;

}

.fp-feat-body { padding: 1rem; }

.fp-feat-title {

  font-size: 1.05rem;

  font-weight: 800;

  line-height: 1.3;

  margin: 0.4rem 0 0.6rem;

}

.fp-feat-title a { color: #fff; transition: color 0.2s; }

.fp-feat-title a:hover { color: #e63946; }

.fp-feat-excerpt { font-size: 0.82rem; color: #888; line-height: 1.55; margin-bottom: 0.75rem; }

.fp-feat-meta { font-size: 0.72rem; color: #666; }



/* Latest updates */

.fp-updates-list { display: flex; flex-direction: column; gap: 0; }

.fp-update-item {

  display: flex;

  gap: 0.75rem;

  padding: 0.75rem 0;

  border-bottom: 1px solid #1a1a1a;

  align-items: flex-start;

}

.fp-update-item:first-child { padding-top: 0; }

.fp-upd-thumb {

  position: relative;

  flex-shrink: 0;

  width: 100px;

  height: 68px;

  overflow: hidden;

  border-radius: 4px;

  display: block;

}

.fp-upd-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s; }

.fp-update-item:hover .fp-upd-thumb img { transform: scale(1.05); }

.fp-upd-dur {

  position: absolute;

  bottom: 3px;

  right: 3px;

  background: rgba(0,0,0,0.8);

  color: #fff;

  font-size: 0.6rem;

  font-weight: 700;

  padding: 1px 4px;

  border-radius: 2px;

}

.fp-upd-content { flex: 1; min-width: 0; }

.fp-upd-title { font-size: 0.82rem; font-weight: 700; line-height: 1.35; margin-bottom: 0.3rem; }

.fp-upd-title a { color: #ddd; transition: color 0.2s; }

.fp-upd-title a:hover { color: #e63946; }

.fp-upd-meta { font-size: 0.7rem; color: #666; }



/* Right sidebar widgets */

.fp-right-sidebar { display: flex; flex-direction: column; gap: 1.25rem; }

.fp-widget {

  background: #111;

  border: 1px solid #1e1e1e;

  border-radius: 6px;

  padding: 1rem;

}

.fp-widget-title {

  font-size: 0.75rem;

  font-weight: 800;

  text-transform: uppercase;

  letter-spacing: 0.1em;

  color: #fff;

  margin-bottom: 0.25rem;

}

.fp-widget-sub { font-size: 0.72rem; color: #666; margin-bottom: 0.75rem; }



/* YouTube widget */

.fp-yt-box {

  background: #1a1a1a;

  border-radius: 6px;

  padding: 0.75rem;

  margin-bottom: 0.75rem;

}

.fp-yt-row { display: flex; align-items: center; gap: 0.6rem; margin-bottom: 0.6rem; }

.fp-yt-icon-wrap {

  width: 36px;

  height: 36px;

  background: #e63946;

  border-radius: 6px;

  display: flex;

  align-items: center;

  justify-content: center;

  color: #fff;

  font-size: 1rem;

  flex-shrink: 0;

}

.fp-yt-info { display: flex; flex-direction: column; }

.fp-yt-info strong { font-size: 0.8rem; color: #fff; }

.fp-yt-info span { font-size: 0.7rem; color: #888; }

.fp-check { color: #1da1f2; margin-left: 3px; }

.fp-yt-sub-btn {

  display: flex;

  align-items: center;

  justify-content: center;

  gap: 0.4rem;

  width: 100%;

  background: #e63946;

  color: #fff;

  font-size: 0.82rem;

  font-weight: 700;

  padding: 0.5rem;

  border-radius: 4px;

  text-decoration: none;

  transition: background 0.2s;

}

.fp-yt-sub-btn:hover { background: #cc0000; color: #fff; }

.fp-yt-desc { font-size: 0.7rem; color: #888; margin-bottom: 0.25rem; }

.fp-yt-privacy { font-size: 0.65rem; color: #555; }



/* Social row */

.fp-social-row { display: flex; gap: 0.5rem; flex-wrap: wrap; }

.fp-soc {

  width: 36px;

  height: 36px;

  border-radius: 50%;

  display: flex;

  align-items: center;

  justify-content: center;

  color: #fff;

  font-size: 0.85rem;

  transition: opacity 0.2s, transform 0.2s;

  text-decoration: none;

}

.fp-soc:hover { opacity: 0.85; transform: translateY(-2px); color: #fff; }

.fp-soc-fb  { background: #1877f2; }

.fp-soc-tw  { background: #000; border: 1px solid #333; }

.fp-soc-ig  { background: linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); }

.fp-soc-yt  { background: #e63946; }

.fp-soc-tt  { background: #010101; border: 1px solid #333; }



/* App buttons */

.fp-app-btns { display: flex; flex-direction: column; gap: 0.5rem; }

.fp-app-btn {

  display: flex;

  align-items: center;

  gap: 0.6rem;

  background: #1a1a1a;

  border: 1px solid #2a2a2a;

  border-radius: 6px;

  padding: 0.5rem 0.75rem;

  color: #fff;

  text-decoration: none;

  transition: border-color 0.2s, background 0.2s;

}

.fp-app-btn:hover { border-color: #e63946; background: #222; color: #fff; }

.fp-app-btn i { font-size: 1.4rem; color: #fff; flex-shrink: 0; }

.fp-app-btn span { display: flex; flex-direction: column; }

.fp-app-btn small { font-size: 0.6rem; color: #888; line-height: 1; }

.fp-app-btn strong { font-size: 0.82rem; font-weight: 700; line-height: 1.3; }



/* ---- ROW 5: VIDEOS + BRIEF + EXCLUSIVES ---- */

.fp-bottom-section {

  padding: 1.5rem 0 2rem;

  background: #0a0a0a;

}

.fp-bottom-grid {

  display: grid;

  grid-template-columns: 1.1fr 1fr 1fr;

  gap: 1.5rem;

  align-items: start;

}



/* Videos */

.fp-videos-list { display: flex; flex-direction: column; gap: 0.75rem; }

.fp-vid-featured { background: #111; border-radius: 6px; overflow: hidden; border: 1px solid #1e1e1e; }

.fp-vid-feat-img {

  display: block;

  position: relative;

  aspect-ratio: 16/9;

  overflow: hidden;

}

.fp-vid-feat-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s; }

.fp-vid-featured:hover .fp-vid-feat-img img { transform: scale(1.04); }

.fp-vid-play-btn {

  position: absolute;

  inset: 0;

  display: flex;

  align-items: center;

  justify-content: center;

  background: rgba(0,0,0,0.3);

  opacity: 0;

  transition: opacity 0.2s;

}

.fp-vid-featured:hover .fp-vid-play-btn { opacity: 1; }

.fp-vid-play-btn i {

  width: 44px;

  height: 44px;

  background: rgba(230,57,70,0.9);

  border-radius: 50%;

  display: flex;

  align-items: center;

  justify-content: center;

  color: #fff;

  font-size: 1rem;

}

.fp-vid-dur {

  position: absolute;

  bottom: 6px;

  left: 6px;

  background: rgba(0,0,0,0.8);

  color: #fff;

  font-size: 0.65rem;

  font-weight: 700;

  padding: 2px 5px;

  border-radius: 3px;

}

.fp-vid-feat-body { padding: 0.75rem; }

.fp-vid-feat-title { font-size: 0.88rem; font-weight: 700; line-height: 1.35; margin-bottom: 0.3rem; }

.fp-vid-feat-title a { color: #ddd; transition: color 0.2s; }

.fp-vid-feat-title a:hover { color: #e63946; }

.fp-vid-meta { font-size: 0.7rem; color: #666; }



.fp-vid-item {

  display: flex;

  gap: 0.6rem;

  align-items: flex-start;

}

.fp-vid-item-img {

  position: relative;

  flex-shrink: 0;

  width: 90px;

  height: 62px;

  overflow: hidden;

  border-radius: 4px;

  display: block;

}

.fp-vid-item-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s; }

.fp-vid-item:hover .fp-vid-item-img img { transform: scale(1.05); }

.fp-vid-dur-sm {

  position: absolute;

  bottom: 3px;

  right: 3px;

  background: rgba(0,0,0,0.8);

  color: #fff;

  font-size: 0.6rem;

  font-weight: 700;

  padding: 1px 4px;

  border-radius: 2px;

}

.fp-vid-item-body { flex: 1; min-width: 0; }

.fp-vid-item-title { font-size: 0.8rem; font-weight: 700; line-height: 1.35; margin-bottom: 0.25rem; }

.fp-vid-item-title a { color: #ddd; transition: color 0.2s; }

.fp-vid-item-title a:hover { color: #e63946; }

.fp-no-img, .fp-no-img-sm, .fp-no-img-excl {

  width: 100%; height: 100%;

  display: flex; align-items: center; justify-content: center;

  background: #1a1a1a; color: #333; font-size: 1.5rem;

}



/* News in brief */

.fp-brief-list { display: flex; flex-direction: column; }

.fp-brief-item {

  display: flex;

  gap: 0.6rem;

  padding: 0.6rem 0;

  border-bottom: 1px solid #1a1a1a;

  align-items: flex-start;

}

.fp-brief-item:last-child { border-bottom: none; }

.fp-brief-img {

  position: relative;

  flex-shrink: 0;

  width: 80px;

  height: 56px;

  overflow: hidden;

  border-radius: 3px;

  display: block;

}

.fp-brief-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s; }

.fp-brief-item:hover .fp-brief-img img { transform: scale(1.05); }

.fp-brief-dur {

  position: absolute;

  bottom: 3px;

  right: 3px;

  background: rgba(0,0,0,0.8);

  color: #fff;

  font-size: 0.6rem;

  font-weight: 700;

  padding: 1px 4px;

  border-radius: 2px;

}

.fp-brief-body { flex: 1; min-width: 0; }

.fp-brief-title { font-size: 0.78rem; font-weight: 600; line-height: 1.35; margin-bottom: 0.2rem; }

.fp-brief-title a { color: #ccc; transition: color 0.2s; }

.fp-brief-title a:hover { color: #e63946; }

.fp-brief-meta { font-size: 0.68rem; color: #666; }



/* Exclusives */

.fp-excl-list { display: flex; flex-direction: column; gap: 1rem; }

.fp-excl-item { display: flex; flex-direction: column; gap: 0; }

.fp-excl-img {

  position: relative;

  display: block;

  aspect-ratio: 16/9;

  overflow: hidden;

  border-radius: 5px;

  margin-bottom: 0.5rem;

}

.fp-excl-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s; }

.fp-excl-item:hover .fp-excl-img img { transform: scale(1.04); }

.fp-excl-dur {

  position: absolute;

  bottom: 6px;

  left: 6px;

  background: rgba(0,0,0,0.8);

  color: #fff;

  font-size: 0.65rem;

  font-weight: 700;

  padding: 2px 5px;

  border-radius: 3px;

}

.fp-excl-play {

  position: absolute;

  inset: 0;

  display: flex;

  align-items: center;

  justify-content: center;

  background: rgba(0,0,0,0.35);

  opacity: 0;

  transition: opacity 0.2s;

}

.fp-excl-item:hover .fp-excl-play { opacity: 1; }

.fp-excl-play i {

  width: 38px; height: 38px;

  background: rgba(230,57,70,0.9);

  border-radius: 50%;

  display: flex; align-items: center; justify-content: center;

  color: #fff; font-size: 0.85rem;

}

.fp-excl-body {}

.fp-excl-title { font-size: 0.82rem; font-weight: 700; line-height: 1.35; margin-bottom: 0.25rem; }

.fp-excl-title a { color: #ddd; transition: color 0.2s; }

.fp-excl-title a:hover { color: #e63946; }

.fp-excl-meta { font-size: 0.7rem; color: #666; }



/* =============================================================

   RESPONSIVE - FRONT PAGE

   ============================================================= */

@media (max-width: 1024px) {

  .fp-hero-politics-grid { grid-template-columns: 1fr; }

  .fp-politics-col { border-left: none; border-top: 1px solid #1e1e1e; }

  .fp-politics-list { display: grid; grid-template-columns: 1fr 1fr; }

  .fp-mid-grid { grid-template-columns: 1fr 1fr; }

  .fp-right-sidebar { grid-column: 1 / -1; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }

  .fp-bottom-grid { grid-template-columns: 1fr 1fr; }

  .fp-excl-col { grid-column: 1 / -1; }

  .fp-excl-list { display: grid; grid-template-columns: repeat(2, 1fr); }

}



@media (max-width: 1024px) {

  .fp-hero-politics-grid { grid-template-columns: 1fr; }

  .fp-politics-col { border-left: none; border-top: 1px solid #1e1e1e; }

  .fp-politics-list { display: grid; grid-template-columns: 1fr 1fr; }

  .fp-mid-grid { grid-template-columns: 1fr 1fr; }

  .fp-right-sidebar { grid-column: 1 / -1; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }

  .fp-bottom-grid { grid-template-columns: 1fr 1fr; }

  .fp-excl-col { grid-column: 1 / -1; }

  .fp-excl-list { display: grid; grid-template-columns: repeat(2, 1fr); }

}



@media (max-width: 768px) {

  .fp-hero-bg { min-height: 320px; }

  .fp-hero-title { font-size: 1.6rem; }

  .fp-hero-content { padding: 1.5rem 1.25rem; }

  .fp-politics-list { grid-template-columns: 1fr; }

  .fp-shows-grid { display: grid; grid-template-columns: repeat(2, 1fr); }

  .fp-mid-grid { grid-template-columns: 1fr; }

  .fp-right-sidebar { grid-column: auto; display: flex; flex-direction: column; }

  .fp-bottom-grid { grid-template-columns: 1fr; }

  .fp-excl-col { grid-column: auto; }

  .fp-excl-list { grid-template-columns: 1fr; }

}



@media (max-width: 480px) {

  .fp-shows-grid { grid-template-columns: 1fr 1fr; }

  .fp-hero-btn { width: 100%; justify-content: center; }

}

/* =============================================================

   ROW 1, ROW 4 & ROW 5 — OLD REFERENCE SITE CLASSES (from Tpare)

   Used by Tpare front-page.php markup for ROW 1 (hero-grid),

   ROW 4 (content-grid) and ROW 5 (lower-grid).

   ============================================================= */

/* ---- ROW 1: HERO + POLITICS (matches reference site) ---- */

.wrap { width: 100%; max-width: 1280px; margin: 0 auto; padding: 0 1.5rem; }

.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 2.1fr) minmax(280px, .9fr);
  gap: 0;
  align-items: stretch;
  margin: 0;
  padding: 0;
}
.live-hero {
  position: relative;
  border-radius: 10px 0 0 10px;
  overflow: hidden;
  background: #07111f;
  color: #fff;
  box-shadow: 0 16px 40px rgba(15,23,42,.12);
  aspect-ratio: 16 / 9;
  min-height: 280px;
  max-height: 70vh;
}
@supports not (aspect-ratio: 16 / 9) {
  .live-hero {
    height: 0;
    padding-bottom: 56.25%;
    min-height: auto;
  }
}
.hero-bg-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
}
.hero-video-container {
  position: absolute;
  inset: 0;
  z-index: 2;
  overflow: hidden;
}
.hero-video-container iframe {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.live-content {
  position: absolute;
  z-index: 2;
  left: 50%;
  top: 70%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 520px;
  width: min(88%, 520px);
  text-align: center;
}
.live-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(4,9,18,.6) 0%, rgba(4,9,18,.3) 60%, rgba(4,9,18,0) 100%);
  z-index: 1;
  pointer-events: none;
}
.live-content p { margin: 0 0 10px; color: #fff; font-weight: 850; text-shadow: 0 2px 10px rgba(0,0,0,.45); }

/* Buttons */
.btn {
  min-height: 44px;
  padding: 0 18px;
  width: fit-content;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border-radius: 5px;
  font-weight: 950;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .02em;
  transition: transform .18s ease, background .18s ease;
}
.btn:hover, .btn:focus { transform: translateY(-2px); }
.btn-red { background: #ec1c24; color: #fff; }
.btn-red:hover, .btn-red:focus { background: #b80d16; }

/* ---- SHARED (matches reference site) ---- */

.section-head { display: flex; align-items: center; justify-content: space-between; margin: 0 0 12px; }

.section-head h2 { margin: 0; font-size: 14px; letter-spacing: .04em; text-transform: uppercase; color: #0b1220; }

.section-head a { color: #ec1c24; font-size: 12px; font-weight: 900; }

/* Panel (used in row 5) */

.panel {

  background: #fff;

  border: 1px solid #e5e8ef;

  border-radius: 10px;

  box-shadow: 0 10px 24px rgba(15,23,42,.06);

}

.panel-title {

  height: 42px;

  padding: 0 14px;

  display: flex;

  align-items: center;

  justify-content: space-between;

  border-bottom: 1px solid #e5e8ef;

  font-size: 13px;

  font-weight: 950;

  text-transform: uppercase;

  color: #0b1220;

}

.panel-title a { color: #ec1c24; text-transform: none; font-size: 11px; font-weight: 900; }

aside .panel { margin: 0; }
.hero-grid .panel { border-radius: 0 10px 10px 0; border: none; box-shadow: none; }

/* Mini list (used in row 5) */

.mini-list { padding: 10px 12px 12px; display: grid; gap: 10px; }

.mini-item {

  display: grid;

  grid-template-columns: 82px 1fr;

  gap: 10px;

  align-items: center;

  padding-bottom: 10px;

  border-bottom: 1px solid #e5e8ef;

}

.mini-item:last-child { border-bottom: 0; padding-bottom: 0; }

.thumb {

  position: relative;

  display: block;

  width: 82px;

  height: 58px;

  border-radius: 7px;

  overflow: hidden;

  background: #111;

}

.thumb img { width: 100%; height: 100%; object-fit: cover; }

.play-icon::after {

  content: "\25B6";

  position: absolute;

  left: 50%; top: 50%;

  transform: translate(-50%, -50%);

  width: 28px; height: 28px;

  display: grid; place-items: center;

  border-radius: 50%;

  background: rgba(236,28,36,.95);

  color: #fff; font-size: 10px;

  box-shadow: 0 8px 18px rgba(0,0,0,.25);

}

.mini-item h3 { margin: 0 0 5px; font-size: 13px; line-height: 1.22; letter-spacing: -.01em; color: #0b1220; }

.mini-item span { color: #687386; font-size: 11px; font-weight: 750; }

/* ---- ROW 4: FEATURED + UPDATES + SIDEBAR (matches reference site) ---- */

.content-grid {

  display: grid;

  grid-template-columns: minmax(0, 1.15fr) minmax(250px, .78fr) minmax(260px, .72fr);

  gap: 18px;

  align-items: start;

}

/* Lead story (featured article) */

.lead-story .image {

  position: relative;

  width: 100%;

  height: 200px;

  background: #111;

  display: block;

  overflow: hidden;

}

.lead-story .image img {

  width: 100%;

  height: 200px;

  object-fit: cover;

}

.category {

  position: absolute;

  left: 14px;

  bottom: 14px;

  background: #ec1c24;

  color: #fff;

  padding: 6px 9px;

  border-radius: 3px;

  font-size: 11px;

  font-weight: 950;

  text-transform: uppercase;

}

.lead-body { padding: 16px 16px 18px; }

.lead-body h2 { margin: 0 0 10px; font-size: clamp(1.45rem, 3vw, 2.1rem); line-height: 1.08; letter-spacing: -.045em; color: #0b1220; }

.lead-body h2 a { color: #0b1220; }

.lead-body p { margin: 0 0 12px; color: #687386; font-size: 14px; }

.byline { color: #687386; font-size: 12px; font-weight: 750; }

/* News stack (latest updates) */

.news-stack { display: grid; gap: 10px; }

.news-card {

  background: #fff;

  border: 1px solid #e5e8ef;

  border-radius: 10px;

  padding: 10px;

  display: grid;

  grid-template-columns: 90px 1fr;

  gap: 10px;

  align-items: center;

}

.news-card img { width: 90px; height: 70px; object-fit: cover; border-radius: 7px; }

.news-card h3 { margin: 0 0 6px; font-size: 13px; line-height: 1.25; color: #0b1220; }

.news-card span { font-size: 11px; color: #687386; font-weight: 750; }

/* Sidebar */

.sidebar { display: grid; gap: 14px; }

.stay-updated { padding: 14px; position: sticky; top: 98px; }

/* YouTube box */

.youtube-box {

  position: relative;

  overflow: hidden;

  padding: 14px;

  border: 1px solid #e5e8ef;

  border-radius: 10px;

  background: linear-gradient(180deg, #ffffff, #f8fafc);

  box-shadow: 0 12px 28px rgba(15,23,42,.08);

}

.youtube-head { display: grid; grid-template-columns: 56px 1fr; gap: 11px; align-items: center; }

.youtube-box img { width: 56px; height: 56px; border-radius: 50%; object-fit: cover; border: 3px solid #fff; box-shadow: 0 8px 16px rgba(15,23,42,.14); }

.youtube-box h3 { margin: 0; font-size: 15px; display: flex; align-items: center; gap: 5px; letter-spacing: -.02em; color: #0b1220; }

.verified {

  width: 14px; height: 14px; border-radius: 50%;

  display: inline-grid; place-items: center;

  background: #2684ff; color: #fff; font-size: 8px;

}

.youtube-box p { margin: 10px 0 12px; color: #687386; font-size: 12px; line-height: 1.45; }

.subscriber-count { display: block; color: #111827; font-size: 11px; font-weight: 900; margin-top: 2px; }

.youtube-subscribe {

  min-height: 34px; padding: 0 12px;

  display: inline-flex; align-items: center; justify-content: center; gap: 6px;

  border-radius: 5px; background: #ff0000; color: #fff;

  font-size: 12px; font-weight: 950;

  box-shadow: 0 10px 20px rgba(255,0,0,.18);

  text-decoration: none;

  transition: background .18s;

}

.youtube-subscribe:hover { background: #cc0000; color: #fff; }

/* Follow title */

.follow-title { margin: 16px 0 8px; font-size: 12px; font-weight: 950; text-transform: uppercase; color: #0b1220; }

.social-icons { display: grid; grid-template-columns: repeat(4, 42px); gap: 10px; }

.social-icons a {

  width: 42px; height: 42px; display: grid; place-items: center;

  border-radius: 9px; color: #fff; font-size: 13px; font-weight: 950;

  text-decoration: none; transition: opacity .18s;

}

.social-icons .fb { background: #1877f2; }

.social-icons .x { background: #111; }

.social-icons .ig { background: linear-gradient(135deg, #f58529, #dd2a7b, #8134af); }

.social-icons .tt { background: linear-gradient(135deg, #010101, #25f4ee 52%, #fe2c55); }

/* App download */

.app-download { margin-top: 14px; padding-top: 12px; border-top: 1px solid #e5e8ef; }

.app-download h3 { margin: 0 0 3px; font-size: 12px; text-transform: uppercase; color: #0b1220; }

.app-download p { margin: 0 0 10px; color: #687386; font-size: 11px; }

.store-row { display: flex; gap: 8px; flex-wrap: wrap; }

.store-badge {

  min-height: 34px; padding: 0 10px;

  display: inline-flex; align-items: center;

  border-radius: 5px; background: #101725; color: #fff;

  font-size: 11px; font-weight: 900;

  text-decoration: none; transition: background .18s;

}
.eyewitness-store-badge {
  background: #e63946;
}
.eyewitness-store-badge:hover {
  background: #c1121f;
}

/* ---- ROW 5: VIDEOS + BRIEF + EXCLUSIVES (matches reference site) ---- */

.lower-grid {

  display: grid;

  grid-template-columns: minmax(0, 1fr) minmax(250px, 1fr) minmax(260px, 1fr);

  gap: 18px;

  margin: 24px 0 34px;

  align-items: start;

}

/* Video main (featured) */

.video-main {

  position: relative;

  border-radius: 10px;

  overflow: hidden;

  min-height: 168px;

  color: #fff;

  background: #111;

  display: block;

  margin-bottom: 10px;

}

.video-main img {

  position: absolute;

  inset: 0;

  width: 100%;

  height: 100%;

  object-fit: cover;

  opacity: .74;

}

.video-main::before {

  content: "\25B6";

  position: absolute;

  left: 50%; top: 44%;

  transform: translate(-50%, -50%);

  width: 42px; height: 42px;

  display: grid; place-items: center;

  border-radius: 50%;

  background: rgba(236, 28, 36, .96);

  color: #fff; z-index: 2;

  font-size: 13px; box-shadow: 0 10px 22px rgba(0,0,0,.3);

}

.video-main::after {

  content: "";

  position: absolute;

  inset: 0;

  background: linear-gradient(180deg, transparent, rgba(0,0,0,.85));

}

.video-main span {

  position: absolute;

  left: 14px; right: 14px; bottom: 14px;

  z-index: 1;

  font-size: 14px; font-weight: 900; color: #fff;

}

/* Brief list */

.brief-list {

  padding: 14px;

  display: grid;

  gap: 11px;

}

.brief-item {

  display: flex;

  align-items: flex-start;

  gap: 0.65rem;

  padding-bottom: 10px;

  border-bottom: 1px solid #e5e8ef;

  text-decoration: none;

}

.brief-item:last-child { border-bottom: 0; padding-bottom: 0; }

.brief-thumb {

  flex-shrink: 0;

  width: 82px;

  height: 58px;

  overflow: hidden;

  border-radius: 7px;

}

.brief-thumb img {

  width: 100%;

  height: 100%;

  object-fit: cover;

}

.brief-text {

  flex: 1;

  min-width: 0;

  font-size: 13px;

  font-weight: 850;

  line-height: 1.28;

  color: #0b1220;

  padding-top: 1px;

  transition: color 0.2s;

}

.brief-item:hover .brief-text { color: #ec1c24; }

/* Responsive breakpoints for old reference site classes */

@media (max-width: 1200px) {

  .hero-grid { grid-template-columns: 1fr 280px; }

  .content-grid { grid-template-columns: 1fr 1fr 260px; }

  .lower-grid { grid-template-columns: 1fr 1fr; }

}

@media (max-width: 1024px) {

  .hero-grid, .content-grid, .lower-grid { grid-template-columns: 1fr 1fr; }

}

@media (max-width: 768px) {

  .hero-grid, .content-grid, .lower-grid { grid-template-columns: 1fr; }

  .live-hero {

    min-height: 200px;

    max-height: 50vh;

    aspect-ratio: 16 / 9;

  }

  .live-content { top: 65%; }

  .live-content p { font-size: 0.8rem; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

}
