/* =============================================================
   SUF Trench Media Hub — dark ESPN-style theme
   Site palette: #0a0a0f bg · #D4AF37 gold · #e05c00 orange
   ============================================================= */

/* ── Variables ────────────────────────────────────────────────── */
:root {
  --tm-bg:        #0a0a0f;
  --tm-surface:   #111118;
  --tm-card:      #16161f;
  --tm-raised:    #1e1e2a;
  --tm-border:    #2a2a38;
  --tm-text:      #e8eaf0;
  --tm-muted:     #7b7d8e;
  --tm-gold:      #D4AF37;
  --tm-gold-h:    #f0cc50;
  --tm-orange:    #e05c00;
  --tm-orange-h:  #ff7a20;
  --tm-r-sm:      6px;
  --tm-r-md:      12px;
  --tm-r-lg:      18px;
  --tm-shadow:    0 8px 40px rgba(0,0,0,.72);
}

/* ── Scoped reset ─────────────────────────────────────────────── */
.suf-tm-hub *,
.suf-tm-hub *::before,
.suf-tm-hub *::after,
.suf-tm-dotw *,
.suf-tm-dotw *::before,
.suf-tm-dotw *::after,
.suf-tm-single *,
.suf-tm-single *::before,
.suf-tm-single *::after {
  box-sizing: border-box;
}

/* =============================================================
   PAGE ROOT (single post)
   ============================================================= */
.suf-tm-single {
  background: var(--tm-bg);
  min-height: 100vh;
  color: var(--tm-text);
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  font-size: 15px;
  line-height: 1.6;
}

/* =============================================================
   HERO STRIP — single post
   ============================================================= */
.suf-tm-single__hero {
  position: relative;
  height: 220px;
  width: 100vw;
  left: 50%;
  transform: translateX(-50%);
  overflow: hidden;
}
.suf-tm-single__hero-bg {
  position: absolute;
  inset: -20px;
  background-size: cover;
  background-position: center;
  filter: blur(18px) brightness(.2) saturate(1.4);
  transform: scale(1.06);
}
.suf-tm-single__hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 0%, var(--tm-bg) 100%);
}

/* =============================================================
   SINGLE WRAP
   ============================================================= */
.suf-tm-single__wrap {
  max-width: 1120px;
  margin: -120px auto 0;
  padding: 0 24px 72px;
  position: relative;
  z-index: 10;
}

/* Video embed — responsive 16:9 */
.suf-tm-single__video-wrap {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  border-radius: var(--tm-r-md);
  overflow: hidden;
  background: #000;
  box-shadow: var(--tm-shadow);
  margin-bottom: 24px;
}
.suf-tm-single__video-wrap iframe,
.suf-tm-single__video-wrap video,
.suf-tm-single__video-wrap object,
.suf-tm-single__video-wrap embed {
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  border: none;
}
.suf-tm-single__video-fallback {
  text-align: center;
  padding: 48px 0 24px;
}
.suf-tm-single__thumb-full {
  border-radius: var(--tm-r-md);
  overflow: hidden;
  margin-bottom: 24px;
  box-shadow: var(--tm-shadow);
}
.suf-tm-single__thumb-full img {
  width: 100%;
  height: auto;
  display: block;
}

/* Meta row */
.suf-tm-single__meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 12px;
  font-size: 13px;
  color: var(--tm-muted);
}
.suf-tm-single__player {
  display: flex;
  align-items: center;
  gap: 5px;
  color: var(--tm-text);
  font-weight: 600;
}
.suf-tm-single__date { color: var(--tm-muted); }

/* Title */
.suf-tm-single__title {
  font-size: 36px !important;
  font-weight: 900 !important;
  line-height: 1.1 !important;
  margin: 0 0 16px !important;
  padding: 0 !important;
  color: #fff !important;
  border: none !important;
  letter-spacing: -.01em;
}

/* Excerpt / content */
.suf-tm-single__excerpt {
  font-size: 17px;
  line-height: 1.75;
  color: var(--tm-muted);
  margin-bottom: 24px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--tm-border);
}
.suf-tm-single__content {
  font-size: 15px;
  line-height: 1.8;
  color: var(--tm-text);
  margin-bottom: 48px;
}
.suf-tm-single__content h2,
.suf-tm-single__content h3 {
  color: var(--tm-gold);
  margin-top: 28px;
}
.suf-tm-single__content a { color: var(--tm-gold); }
.suf-tm-single__content a:hover { color: var(--tm-gold-h); }

/* Related videos section */
.suf-tm-single__related { margin-top: 48px; }
.suf-tm-single__related-title {
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase;
  letter-spacing: .15em;
  color: var(--tm-muted) !important;
  margin: 0 0 20px !important;
  padding-bottom: 12px !important;
  border-bottom: 1px solid var(--tm-border) !important;
  border-top: none !important;
  border-left: none !important;
  border-right: none !important;
}

/* =============================================================
   DOG OF THE WEEK — featured card
   ============================================================= */
.suf-tm-dotw {
  background: var(--tm-surface);
  border: 1px solid var(--tm-border);
  border-left: 3px solid var(--tm-gold);
  border-radius: var(--tm-r-lg);
  overflow: hidden;
  margin-bottom: 36px;
  box-shadow: var(--tm-shadow);
  animation: tm-fadein .4s ease both;
}
.suf-tm-dotw__badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--tm-gold);
  color: #0a0a0f;
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .15em;
  padding: 6px 14px;
  border-radius: 0 0 var(--tm-r-sm) 0;
}
.suf-tm-dotw__inner {
  display: grid;
  grid-template-columns: 420px 1fr;
}
.suf-tm-dotw__thumb {
  position: relative;
  background: #000 center/cover no-repeat;
  min-height: 260px;
}
.suf-tm-dotw__thumb-placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--tm-raised);
  color: var(--tm-muted);
}
.suf-tm-dotw__thumb-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, transparent 60%, rgba(10,10,15,.95) 100%);
}
.suf-tm-dotw__play {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  text-decoration: none;
}
.suf-tm-dotw__play svg {
  width: 60px;
  height: 60px;
  background: rgba(212,175,55,.18);
  border: 2px solid var(--tm-gold);
  border-radius: 50%;
  padding: 16px;
  transition: background .2s ease, transform .15s ease;
}
.suf-tm-dotw__play:hover svg {
  background: rgba(212,175,55,.38);
  transform: scale(1.08);
}
.suf-tm-dotw__body {
  padding: 28px 32px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 14px;
}
.suf-tm-dotw__player {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--tm-gold);
}
.suf-tm-dotw__title {
  font-size: 26px !important;
  font-weight: 900 !important;
  line-height: 1.15 !important;
  margin: 0 !important;
  padding: 0 !important;
  color: #fff !important;
  border: none !important;
}
.suf-tm-dotw__desc {
  font-size: 14px;
  line-height: 1.65;
  color: var(--tm-muted);
  margin: 0;
}

/* =============================================================
   MEDIA HUB WRAPPER (shortcode root)
   ============================================================= */
.suf-tm-hub {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  color: var(--tm-text);
}

/* =============================================================
   FILTER TABS
   ============================================================= */
.suf-tm-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 28px;
}
.suf-tm-filter-btn {
  background: var(--tm-raised);
  color: var(--tm-muted);
  border: 1px solid var(--tm-border);
  border-radius: 100px;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 8px 18px;
  cursor: pointer;
  transition: background .15s ease, color .15s ease, border-color .15s ease;
  line-height: 1;
}
.suf-tm-filter-btn:hover {
  background: var(--tm-border);
  color: var(--tm-text);
}
.suf-tm-filter-btn.is-active {
  background: var(--tm-gold);
  color: #0a0a0f;
  border-color: var(--tm-gold);
}

/* =============================================================
   VIDEO GRID
   ============================================================= */
.suf-tm-grid {
  display: grid;
  gap: 20px;
}
.suf-tm-grid--3col { grid-template-columns: repeat(3, 1fr); }
.suf-tm-grid--2col { grid-template-columns: repeat(2, 1fr); }

.suf-tm-empty,
.suf-tm-no-results p {
  color: var(--tm-muted);
  font-size: 14px;
  text-align: center;
  padding: 48px 0;
  grid-column: 1 / -1;
}

/* =============================================================
   VIDEO CARD
   ============================================================= */
.suf-tm-card {
  background: var(--tm-card);
  border: 1px solid var(--tm-border);
  border-radius: var(--tm-r-md);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .18s ease, box-shadow .18s ease;
  animation: tm-fadein .35s ease both;
}
.suf-tm-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0,0,0,.65);
}

/* Thumbnail */
.suf-tm-card__thumb-wrap {
  display: block;
  text-decoration: none;
}
.suf-tm-card__thumb {
  position: relative;
  width: 100%;
  padding-top: 56.25%; /* 16:9 */
  background: var(--tm-raised) center/cover no-repeat;
}
.suf-tm-card__thumb-placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--tm-border);
}
.suf-tm-card__thumb-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(10,10,15,.8) 0%, transparent 50%);
  transition: background .2s ease;
}
.suf-tm-card:hover .suf-tm-card__thumb-overlay {
  background: linear-gradient(to top, rgba(10,10,15,.9) 0%, rgba(10,10,15,.2) 100%);
}
.suf-tm-card__play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(.8);
  width: 44px;
  height: 44px;
  background: rgba(212,175,55,.15);
  border: 1.5px solid var(--tm-gold);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--tm-gold);
  opacity: 0;
  transition: opacity .2s ease, transform .2s ease;
}
.suf-tm-card:hover .suf-tm-card__play {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

/* Card body */
.suf-tm-card__body {
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}
.suf-tm-card__title {
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  color: var(--tm-text) !important;
}
.suf-tm-card__title a {
  color: inherit !important;
  text-decoration: none !important;
}
.suf-tm-card__title a:hover { color: var(--tm-gold) !important; }
.suf-tm-card__player {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  color: var(--tm-muted);
}
.suf-tm-card__body .suf-tm-btn { margin-top: auto; align-self: flex-start; }

/* =============================================================
   CATEGORY BADGES
   ============================================================= */
.suf-tm-card__badge {
  display: inline-block;
  font-size: 9px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .1em;
  padding: 3px 9px;
  border-radius: 3px;
  text-decoration: none;
}
/* Dog of the Week */
.suf-tm-badge--dog-of-the-week  { background: rgba(212,175,55,.15); color: var(--tm-gold); border: 1px solid rgba(212,175,55,.35); }
/* Player Interviews */
.suf-tm-badge--player-interviews { background: rgba(224,92,0,.15);  color: #ff9a50;       border: 1px solid rgba(224,92,0,.35); }
/* Camp Highlights */
.suf-tm-badge--camp-highlights   { background: rgba(66,165,245,.12); color: #64b5f6;       border: 1px solid rgba(66,165,245,.3); }
/* Top Performers */
.suf-tm-badge--top-performers    { background: rgba(0,200,83,.1);    color: #69f0ae;       border: 1px solid rgba(0,200,83,.28); }

/* =============================================================
   BUTTONS
   ============================================================= */
.suf-tm-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 9px 16px;
  border-radius: var(--tm-r-sm);
  text-decoration: none !important;
  border: none;
  cursor: pointer;
  transition: background .18s ease, transform .15s ease;
  line-height: 1;
  color: #0a0a0f !important;
  background: var(--tm-gold);
}
.suf-tm-btn:hover {
  background: var(--tm-gold-h);
  transform: translateY(-1px);
  color: #0a0a0f !important;
}
.suf-tm-btn--gold { background: var(--tm-gold); color: #0a0a0f !important; }
.suf-tm-btn--gold:hover { background: var(--tm-gold-h); }
.suf-tm-btn--lg { padding: 14px 28px; font-size: 13px; }
.suf-tm-btn--sm { padding: 7px 12px; font-size: 10px; }

/* =============================================================
   ANIMATION
   ============================================================= */
@keyframes tm-fadein {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Stagger card animations */
.suf-tm-card:nth-child(1) { animation-delay: .04s; }
.suf-tm-card:nth-child(2) { animation-delay: .08s; }
.suf-tm-card:nth-child(3) { animation-delay: .12s; }
.suf-tm-card:nth-child(4) { animation-delay: .16s; }
.suf-tm-card:nth-child(5) { animation-delay: .20s; }
.suf-tm-card:nth-child(6) { animation-delay: .24s; }

/* Cards hidden by filter */
.suf-tm-card.is-hidden {
  display: none;
}

/* =============================================================
   RESPONSIVE
   ============================================================= */
@media (max-width: 900px) {
  .suf-tm-dotw__inner { grid-template-columns: 1fr; }
  .suf-tm-dotw__thumb { min-height: 220px; padding-top: 56%; }
  .suf-tm-dotw__thumb-overlay { background: linear-gradient(to top, rgba(10,10,15,.95) 0%, transparent 60%); }
  .suf-tm-dotw__body { padding: 20px 24px; }
  .suf-tm-grid--3col { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
  .suf-tm-single__title { font-size: 26px !important; }
  .suf-tm-dotw__title { font-size: 20px !important; }
  .suf-tm-grid--3col,
  .suf-tm-grid--2col { grid-template-columns: 1fr; }
  .suf-tm-single__wrap { margin-top: -80px; padding: 0 16px 48px; }
  .suf-tm-filters { gap: 6px; }
  .suf-tm-filter-btn { padding: 7px 13px; font-size: 11px; }
}
