/* MCTV player — branded shell around the Vimeo SDK, watch hub, pop-out window. */

.mctv-watch { padding: 56px 0 90px; }
.mctv-watch__h1 { font-size: clamp(2.4rem, 6vw, 4rem); font-weight: 900; letter-spacing: -1.5px; line-height: 1; margin: 14px 0 26px; }
.mctv-watch__h1 .pop { color: var(--red); }
.mctv-watch__empty { text-align: center; color: #5b626b; }
.mctv-watch__empty .mctv-player { margin: 0 auto 20px; }
.mctv-watch__admin a { color: var(--red); font-weight: 800; }

/* ── The player shell ─────────────────────────────────────────────────── */
.mctv-player {
  position: relative;
  aspect-ratio: 16 / 9;
  width: 100%;
  background: #000;
  border: 4px solid var(--ink);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: var(--shadow);
  isolation: isolate;
}
.mctv-player.is-loading { cursor: progress; }

/* Vimeo iframe fills the shell */
.mctv-player iframe { position: absolute; inset: 0; width: 100% !important; height: 100% !important; border: 0; }

/* Poster (before first play) */
.mctv-player__poster {
  position: absolute; inset: 0; z-index: 2;
  background: #14161b center/cover no-repeat;
  cursor: pointer;
}
.mctv-player__poster::after {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(60% 60% at 50% 45%, transparent, rgba(0,0,0,.35));
}

/* Big center play button */
.mctv-player__big {
  position: absolute; z-index: 3; top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 88px; height: 88px; border-radius: 50%; border: 0; cursor: pointer;
  background: var(--yellow); box-shadow: 0 12px 34px rgba(0,0,0,.45);
  display: grid; place-items: center; transition: transform .12s ease, background .12s ease;
}
.mctv-player__big:hover { transform: translate(-50%, -50%) scale(1.06); }
.mctv-player__big::after {
  content: ""; margin-left: 6px;
  border-left: 28px solid var(--ink); border-top: 17px solid transparent; border-bottom: 17px solid transparent;
}
.mctv-player.is-playing .mctv-player__big,
.mctv-player.is-started .mctv-player__poster { display: none; }

/* Control bar */
.mctv-player__bar {
  position: absolute; z-index: 4; left: 0; right: 0; bottom: 0;
  display: flex; align-items: center; gap: 12px;
  padding: 26px 16px 12px;
  background: linear-gradient(transparent, rgba(0,0,0,.78));
  opacity: 0; transform: translateY(6px); transition: opacity .2s ease, transform .2s ease;
  color: #fff;
}
.mctv-player:hover .mctv-player__bar,
.mctv-player.is-paused .mctv-player__bar,
.mctv-player:focus-within .mctv-player__bar { opacity: 1; transform: none; }

.mctv-btn {
  appearance: none; border: 0; background: transparent; color: #fff; cursor: pointer;
  width: 34px; height: 34px; border-radius: 9px; display: grid; place-items: center; flex: none;
  transition: background .12s ease, color .12s ease;
}
.mctv-btn:hover { background: rgba(255,255,255,.16); }
.mctv-btn svg { width: 20px; height: 20px; fill: currentColor; display: block; }
.mctv-btn--accent:hover { color: var(--yellow); }

.mctv-player__time { font-size: 12px; font-weight: 700; font-variant-numeric: tabular-nums; white-space: nowrap; letter-spacing: .3px; }

/* Scrubber */
.mctv-player__seek {
  flex: 1; height: 6px; border-radius: 999px; cursor: pointer; position: relative;
  background: rgba(255,255,255,.28);
}
.mctv-player__seek-buf { position: absolute; inset: 0; width: 0; background: rgba(255,255,255,.25); border-radius: 999px; }
.mctv-player__seek-fill { position: absolute; inset: 0; width: 0; background: var(--red); border-radius: 999px; }
.mctv-player__seek-fill::after {
  content: ""; position: absolute; right: -6px; top: 50%; transform: translateY(-50%);
  width: 13px; height: 13px; border-radius: 50%; background: #fff; box-shadow: 0 1px 4px rgba(0,0,0,.5);
  opacity: 0; transition: opacity .12s;
}
.mctv-player__seek:hover .mctv-player__seek-fill::after { opacity: 1; }

/* Volume */
.mctv-player__vol { width: 74px; height: 5px; accent-color: var(--yellow); cursor: pointer; }
@media (max-width: 640px) { .mctv-player__vol { display: none; } }

.mctv-player__spacer { flex: 1; }
.mctv-player__title-badge {
  position: absolute; z-index: 4; top: 14px; left: 16px; right: 16px;
  font-weight: 800; font-size: 14px; color: #fff; text-shadow: 0 1px 12px rgba(0,0,0,.7);
  opacity: 0; transition: opacity .2s ease; pointer-events: none;
}
.mctv-player:hover .mctv-player__title-badge, .mctv-player.is-paused .mctv-player__title-badge { opacity: 1; }

/* Placeholder (empty watch page) */
.mctv-player--placeholder { max-width: 860px; display: grid; place-items: center; }
.mctv-player--placeholder .mctv-player__big { position: static; transform: none; }

/* ── Library grid ─────────────────────────────────────────────────────── */
.mctv-lib { margin-top: 44px; }
.mctv-lib__head { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-bottom: 20px; }
.mctv-lib__head h2 { font-size: clamp(1.5rem, 3vw, 2.1rem); font-weight: 900; letter-spacing: -.6px; margin: 0; }
.mctv-lib__count { display: inline-grid; place-items: center; min-width: 30px; height: 26px; padding: 0 9px; margin-left: 6px; border-radius: 999px; background: var(--ink); color: #fff; font-size: 13px; vertical-align: middle; }
.mctv-search { font: inherit; font-weight: 600; padding: 11px 16px; border: 3px solid var(--ink); border-radius: 999px; min-width: 240px; box-shadow: 0 4px 0 var(--ink); }
.mctv-search:focus { outline: none; border-color: var(--red); }

.mctv-lib__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
@media (max-width: 1000px) { .mctv-lib__grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 720px)  { .mctv-lib__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 460px)  { .mctv-lib__grid { grid-template-columns: 1fr; } }

.mctv-tile { appearance: none; border: 0; background: transparent; padding: 0; text-align: left; cursor: pointer; display: block; }
.mctv-tile__thumb {
  display: block; position: relative; aspect-ratio: 16/9; border-radius: 14px; overflow: hidden;
  background: #14161b center/cover no-repeat; border: 3px solid var(--ink); box-shadow: 0 5px 0 var(--ink);
  transition: transform .15s ease, box-shadow .15s ease;
}
.mctv-tile:hover .mctv-tile__thumb, .mctv-tile:focus-visible .mctv-tile__thumb { transform: translateY(-4px); box-shadow: 0 10px 0 var(--ink); }
.mctv-tile__play {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 52px; height: 52px; border-radius: 50%; background: rgba(255,255,255,.94);
  display: grid; place-items: center; opacity: 0; transition: opacity .15s ease;
}
.mctv-tile:hover .mctv-tile__play, .mctv-tile:focus-visible .mctv-tile__play { opacity: 1; }
.mctv-tile__play::after { content: ""; margin-left: 4px; border-left: 16px solid var(--ink); border-top: 10px solid transparent; border-bottom: 10px solid transparent; }
.mctv-tile__dur { position: absolute; right: 8px; bottom: 8px; background: rgba(0,0,0,.82); color: #fff; font-size: 11px; font-weight: 700; padding: 3px 7px; border-radius: 6px; font-variant-numeric: tabular-nums; }
.mctv-tile__title { display: block; margin-top: 11px; font-weight: 700; font-size: .98rem; line-height: 1.3; color: var(--ink); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.mctv-tile.is-active .mctv-tile__thumb { border-color: var(--red); box-shadow: 0 5px 0 var(--red); }
.mctv-lib__empty { text-align: center; color: #8a9099; font-weight: 600; padding: 26px 0; }

/* Episode player on single posts */
.mctv-episode-player { margin: 0 0 30px; }

/* ── Detached pop-out window (?mctv_player=) ──────────────────────────── */
.mctv-solo-body { margin: 0; background: #0b0c0f; min-height: 100vh; display: grid; place-items: center; }
.mctv-solo-wrap { width: 100%; height: 100vh; }
.mctv-solo-wrap .mctv-player { height: 100vh; aspect-ratio: auto; border: 0; border-radius: 0; box-shadow: none; }

/* ── Native PiP note ──────────────────────────────────────────────────── */
.mctv-player__note {
  position: absolute; z-index: 5; inset: 0; display: grid; place-items: center; text-align: center;
  background: rgba(11,12,15,.92); color: #fff; font-weight: 700; padding: 24px; gap: 10px;
}
.mctv-player__note[hidden] { display: none; }
.mctv-player__note small { display: block; color: var(--gray); font-weight: 500; margin-top: 6px; }
